UploadPatentBatchService.java 42 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777
  1. package cn.cslg.pas.service;
  2. import cn.cslg.pas.common.core.base.Constants;
  3. import cn.cslg.pas.common.model.PatentCell;
  4. import cn.cslg.pas.common.model.dto.TaskWebSocketDTO;
  5. import cn.cslg.pas.common.model.params.*;
  6. import cn.cslg.pas.common.model.vo.ProjectImportPatentVO;
  7. import cn.cslg.pas.common.model.vo.TaskParams;
  8. import cn.cslg.pas.common.model.vo.UploadParamsVO;
  9. import cn.cslg.pas.common.model.vo.UploadSettingVO;
  10. import cn.cslg.pas.common.utils.*;
  11. import cn.cslg.pas.domain.*;
  12. import cn.cslg.pas.mapper.ImportErrorLogMapper;
  13. import cn.cslg.pas.service.asso.AssoProductPatentService;
  14. import cn.hutool.extra.spring.SpringUtil;
  15. import com.baomidou.mybatisplus.core.toolkit.Wrappers;
  16. import lombok.RequiredArgsConstructor;
  17. import org.apache.poi.ss.usermodel.PictureData;
  18. import org.springframework.context.annotation.Lazy;
  19. import org.springframework.scheduling.annotation.Async;
  20. import org.springframework.stereotype.Service;
  21. import org.springframework.transaction.annotation.Transactional;
  22. import org.springframework.transaction.interceptor.TransactionAspectSupport;
  23. import java.text.ParseException;
  24. import java.text.SimpleDateFormat;
  25. import java.util.*;
  26. import java.util.stream.Collectors;
  27. @Service
  28. @RequiredArgsConstructor(onConstructor_ = {@Lazy})
  29. public class UploadPatentBatchService {
  30. private final FileUtils fileUtils;
  31. private final SystemDictService systemDictService;
  32. private final PatentImageService patentImageService;
  33. private final PatentService patentService;
  34. private final PatentAgencyService patentAgencyService;
  35. private final PatentInstructionTextService patentInstructionTextService;
  36. private final PatentRightService patentRightService;
  37. private final PatentAgentService patentAgentService;
  38. private final PatentPledgeService patentPledgeService;
  39. private final PatentLicensorService patentLicensorService;
  40. private final PatentSimpleFamilyService patentSimpleFamilyService;
  41. private final PatentInventorService patentInventorService;
  42. private final ProjectPatentLinkService projectPatentLinkService;
  43. private final ProjectFieldPatentLinkService projectFieldPatentLinkService;
  44. private final ProjectFolderPatentLinkService projectFolderPatentLinkService;
  45. private final PatentApplicantLinkService patentApplicantLinkService;
  46. private final PatentApplicantService patentApplicantService;
  47. private final PatentLabelService patentLabelService;
  48. private final PatentClassNumberLinkService patentClassNumberLinkService;
  49. private final PatentAffairService patentAffairService;
  50. private final ImportErrorLogMapper importErrorLogMapper;
  51. private final AssoProductPatentService assoProductPatentService;
  52. private final PatentInstructionService patentInstructionService;
  53. private static int FLAG = 0;
  54. @Async("singleThreadAsyncTaskExecutor")
  55. public void uploadPatentBatch(TaskParams params, ProjectImportPatentVO projectImportPatentVO) {
  56. Integer total = params.getRowList().size();
  57. try {
  58. //先解析Json文件 获得配置文件的Json串
  59. String getSettingJson = fileUtils.analysisJsonFile();
  60. //查找需求数据源的对应配置
  61. List<UploadSettingVO.Column> jsonData = UploadPatentBatchUtil.parsingConfigurationFiles(projectImportPatentVO, getSettingJson);
  62. Map<String, PictureData> pictureDataMap = ExcelUtils.getDataFromExcel(params.getPath());
  63. //将数据进行装配并进行数据库操作
  64. for (int i = 0; i < params.getRowList().size(); i++) {
  65. //获取每一行的数据
  66. Map<Object, Object> row = params.getRowList().get(i);
  67. //基础数据装配
  68. UploadParamsVO uploadParamsVO = UploadPatentBatchUtil.processData(row, jsonData);
  69. //查询数据是否存在 如果存在 返回该条数据 如果不存在 新增一条数据
  70. getOneOrInsertOne(uploadParamsVO);
  71. //专利信息需要特殊处理部分
  72. //专利信息(摘要附图)数据装配
  73. PictureData pictureData = pictureDataMap.get(String.valueOf(i + 1));
  74. if (uploadParamsVO.getPatent() != null) {
  75. if (uploadParamsVO.getPatent().getId() != null && pictureData != null) {
  76. uploadParamsVO.getPatent().setAbstractPath(patentImageService.updatePatentImage(uploadParamsVO.getPatent().getId(), pictureData));
  77. }
  78. }
  79. //专利信息(代理机构)数据装配
  80. if (uploadParamsVO.getPatent() != null) {
  81. if (uploadParamsVO.getPatent().getAgencyId() != null) {
  82. uploadParamsVO.getPatent().setAgencyId(patentAgencyService.getAgencyStringIdByName(uploadParamsVO.getPatent().getAgencyId()));
  83. }
  84. }
  85. //将装配对象中的数据保存到数据库
  86. dataToDB(params, uploadParamsVO, projectImportPatentVO);
  87. //通过WebSocket 在每一次循环结束后 向前端发送完成进度
  88. WebSocketServer.sendInfo(Response.websocket(new TaskWebSocketDTO()
  89. .setTaskId(params.getTaskId())
  90. .setProjectId(projectImportPatentVO.getProjectId())
  91. .setComplete(false)
  92. .setIndex(i)
  93. .setTaskType(Constants.TASK_IMPORT_PATENT)
  94. .setPercentage(total == 0 ? 0 : Math.round((total.equals(i) ? (i * 1D) : (i + 1D)) / total * 100D))
  95. .setFileName("")
  96. .setOldName(params.getOldName())
  97. .setUrl("")
  98. .setTotal(total), ResponseEnum.PATENT_IMPORT_TASK_SUCCESS), params.getUserId());
  99. }
  100. SpringUtil.getBean(ProjectService.class).setImportPatentTaskStatus(2, params.getTaskId());
  101. WebSocketServer.sendInfo(Response.websocket(new TaskWebSocketDTO()
  102. .setTaskId(params.getTaskId())
  103. .setProjectId(projectImportPatentVO.getProjectId())
  104. .setComplete(true)
  105. .setIndex(total)
  106. .setTaskType(Constants.TASK_IMPORT_PATENT)
  107. .setPercentage(100L)
  108. .setFileName("")
  109. .setOldName(params.getOldName())
  110. .setUrl("")
  111. .setTotal(total), ResponseEnum.PATENT_IMPORT_TASK_SUCCESS), params.getUserId());
  112. } catch (Exception e) {
  113. e.printStackTrace();
  114. SpringUtil.getBean(ProjectService.class).setImportPatentTaskStatus(3, params.getTaskId());
  115. if (FLAG > 0) {
  116. int successCount = total - FLAG;
  117. WebSocketServer.sendInfo(Response.error("部分数据上传成功" + "\n" + "成功条数:" + successCount + "失败条数:" + FLAG), params.getUserId());
  118. }
  119. FLAG = 0;
  120. }
  121. }
  122. /**
  123. * @return uploadParamsVO 返回一个由processData方法填充完数据的Pojo类
  124. * @date 2022/7/7
  125. * @name 解析配置文件
  126. * @description uploadPatentBatch的兄弟方法
  127. */
  128. // @Async("singleThreadAsyncTaskExecutor")
  129. public String uploadPatentBatchBro(TaskParams params) {
  130. Integer total = params.getTotal();
  131. Integer index = params.getIndex();
  132. try {
  133. //先解析Json文件 获得配置文件的Json串
  134. String getSettingJson = fileUtils.analysisJsonFile();
  135. //查找需求数据源的对应配置
  136. List<UploadSettingVO.Column> jsonData = UploadPatentBatchUtil.parsingConfigurationFilesBro(getSettingJson);
  137. Map<String, PictureData> pictureDataMap = ExcelUtils.getDataFromExcel(params.getPath());
  138. //将数据进行装配并进行数据库操作
  139. //获取每一行的数据
  140. Map<Object, Object> row = params.getRowList().get(0);
  141. //基础数据装配
  142. UploadParamsVO uploadParamsVO = UploadPatentBatchUtil.processData(row, jsonData);
  143. //查询数据是否存在 如果存在 返回该条数据 如果不存在 新增一条数据
  144. getOneOrInsertOne(uploadParamsVO);
  145. //专利信息需要特殊处理部分
  146. //专利信息(摘要附图)数据装配
  147. PictureData pictureData = pictureDataMap.get(String.valueOf(index + 1));
  148. if (uploadParamsVO.getPatent() != null) {
  149. if (uploadParamsVO.getPatent().getId() != null && pictureData != null) {
  150. uploadParamsVO.getPatent().setAbstractPath(patentImageService.updatePatentImage(uploadParamsVO.getPatent().getId(), pictureData));
  151. }
  152. }
  153. //专利信息(代理机构)数据装配
  154. if (uploadParamsVO.getPatent() != null) {
  155. if (uploadParamsVO.getPatent().getAgencyId() != null) {
  156. uploadParamsVO.getPatent().setAgencyId(patentAgencyService.getAgencyStringIdByName(uploadParamsVO.getPatent().getAgencyId()));
  157. }
  158. }
  159. //将装配对象中的数据保存到数据库
  160. dataToDBBro(params, uploadParamsVO);
  161. ImportTaskPatent importTaskPatent = new ImportTaskPatent();
  162. importTaskPatent.setImportTaskId(params.getTaskId());
  163. importTaskPatent.setPatentNo(uploadParamsVO.getPatent().getPatentNo());
  164. importTaskPatent.insert();
  165. //通过WebSocket 在每一次循环结束后 向前端发送完成进度
  166. WebSocketServer.sendInfo(Response.websocket(new TaskWebSocketDTO()
  167. .setTaskId(params.getTaskId())
  168. .setComplete(false)
  169. .setIndex(0)
  170. .setTaskType(Constants.TASK_IMPORT_PATENT)
  171. .setPercentage(total == 0 ? 0 : Math.round((total.equals(index) ? (index * 1D) : (index + 1D)) / total * 100D))
  172. .setFileName("")
  173. .setOldName(params.getOldName())
  174. .setUrl("")
  175. .setTotal(total), ResponseEnum.PATENT_IMPORT_TASK_SUCCESS), params.getUserId());
  176. return Response.success();
  177. } catch (Exception e) {
  178. return Response.error();
  179. }
  180. }
  181. /**
  182. * @param uploadParamsVO 全局类
  183. * @date 2022-7-11
  184. * @name 数据库交互
  185. * @description 将装配完毕的VO类向数据库中不同的表进行添加或修改操作
  186. */
  187. @Transactional(rollbackFor = Exception.class)
  188. public void dataToDB(TaskParams params, UploadParamsVO uploadParamsVO, ProjectImportPatentVO projectImportPatentVO) {
  189. try {
  190. //专利信息 OS_PATENT
  191. if (uploadParamsVO.getPatent() != null) {
  192. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Collections.singletonList(Constants.PATENT_SIMPLE_STATUS));
  193. Integer simpleStatus = Integer.parseInt(systemDictList.stream()
  194. .filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getLabel().equals(uploadParamsVO.getPatentSimpleStatus()))
  195. .findFirst()
  196. .orElse(new SystemDict()).getValue());
  197. uploadParamsVO.getPatent().setSimpleStatus(simpleStatus);
  198. uploadParamsVO.getPatent().updateById();
  199. }
  200. //权利要求 OS_PATENT_RIGHT
  201. patentRightBusiness(uploadParamsVO);
  202. //说明书(文本) OS_PATENT_INSTRUCTION_TEXT
  203. if (uploadParamsVO.getPatentInstructionText() != null) {
  204. patentInstructionTextBusiness(uploadParamsVO);
  205. }
  206. //代理人 OS_PATENT_AGENT
  207. if (uploadParamsVO.getPatentAgentList() != null) {
  208. patentAgentBusiness(uploadParamsVO);
  209. }
  210. //质押质权人 OS_PATENT_PLEDGE
  211. if (uploadParamsVO.getPatentPledgeList() != null) {
  212. patentPledgeBusiness(uploadParamsVO);
  213. }
  214. //许可人 OS_PATENT_LICENSOR
  215. if (uploadParamsVO.getPatentLicensorList() != null) {
  216. patentLicensorBusiness(uploadParamsVO);
  217. }
  218. //简单同族 OS_PATENT_SIMPLEFAMILY
  219. patentSimplyFamilyBusiness(uploadParamsVO);
  220. //发明人 OS_PATENT_INVENTOR
  221. patentInventorBusiness(uploadParamsVO);
  222. //申请人(原始)/权利人(当前) OS_PATENT_APPLICATION || OS_APPLICATION_ATTR
  223. patentApplicationBusiness(uploadParamsVO);
  224. //申请人地址 OS_PATENT_APPLICATION
  225. patentApplicationAddressBusiness(uploadParamsVO);
  226. //专题库关联专利信息 OS_THEMATIC_PID
  227. if (uploadParamsVO.getPatent() != null) {
  228. patentThematicPidBusiness(uploadParamsVO, projectImportPatentVO);
  229. }
  230. //标引内容关联专利信息 OS_PATENT_FIELD_PATENT_LINK
  231. if (uploadParamsVO.getPatent() != null) {
  232. patentProjectFieldPatentLinkBusiness(uploadParamsVO, projectImportPatentVO);
  233. }
  234. //文件夹管理 OS_PORTFOLIO_LINK
  235. if (uploadParamsVO.getPatent() != null) {
  236. patentProjectFolderPatentLinkBusiness(uploadParamsVO, projectImportPatentVO);
  237. }
  238. //标签 OS_PATENT_LABEL
  239. if (uploadParamsVO.getPatentLabelList() != null) {
  240. patentLabelBusiness(uploadParamsVO, projectImportPatentVO);
  241. }
  242. //分类号关联 OS_PATENT_TYPENO
  243. patentTypeNoBusiness(uploadParamsVO);
  244. //事务信息 OS_PATENT_AFFAIR
  245. patentAffairBusiness(uploadParamsVO);
  246. //自定义字段
  247. if (uploadParamsVO.getCustomerFieldList() != null) {
  248. patentFieldBusiness(params, uploadParamsVO, projectImportPatentVO);
  249. }
  250. } catch (Exception e) {
  251. e.printStackTrace();
  252. if (uploadParamsVO.getPatent() != null) {
  253. ImportErrorLog importErrorLog = new ImportErrorLog();
  254. importErrorLog.setPatentId(uploadParamsVO.getPatent().getId())
  255. .setPatentNo(uploadParamsVO.getPatent().getPatentNo())
  256. .setCreateTime(new SimpleDateFormat("yyyy-MM-dd 24HI:mm:ss").format(new Date()))
  257. .setCreateUserId(Integer.parseInt(params.getUserId()))
  258. .setMistakeMessage(e.getMessage())
  259. .setProjectId(params.getProjectId());
  260. importErrorLogMapper.insert(importErrorLog);
  261. FLAG += 1;
  262. }
  263. TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
  264. }
  265. }
  266. /**
  267. * @param uploadParamsVO 全局类
  268. * @date 2022-7-11
  269. * @name 数据库交互
  270. * @description 将装配完毕的VO类向数据库中不同的表进行添加或修改操作(dataToDB兄弟类)
  271. */
  272. @Transactional(rollbackFor = Exception.class)
  273. public void dataToDBBro(TaskParams params, UploadParamsVO uploadParamsVO) {
  274. try {
  275. //专利信息 OS_PATENT
  276. if (uploadParamsVO.getPatent() != null) {
  277. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Collections.singletonList(Constants.PATENT_SIMPLE_STATUS));
  278. Integer simpleStatus = Integer.parseInt(systemDictList.stream()
  279. .filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getLabel().equals(uploadParamsVO.getPatentSimpleStatus()))
  280. .findFirst()
  281. .orElse(new SystemDict()).getValue());
  282. uploadParamsVO.getPatent().setSimpleStatus(simpleStatus);
  283. uploadParamsVO.getPatent().updateById();
  284. }
  285. //权利要求 OS_PATENT_RIGHT
  286. patentRightBusiness(uploadParamsVO);
  287. //说明书(文本) OS_PATENT_INSTRUCTION_TEXT
  288. if (uploadParamsVO.getPatentInstructionText() != null) {
  289. patentInstructionTextBusiness(uploadParamsVO);
  290. }
  291. //代理人 OS_PATENT_AGENT
  292. if (uploadParamsVO.getPatentAgentList() != null) {
  293. patentAgentBusiness(uploadParamsVO);
  294. }
  295. //质押质权人 OS_PATENT_PLEDGE
  296. if (uploadParamsVO.getPatentPledgeList() != null) {
  297. patentPledgeBusiness(uploadParamsVO);
  298. }
  299. //许可人 OS_PATENT_LICENSOR
  300. if (uploadParamsVO.getPatentLicensorList() != null) {
  301. patentLicensorBusiness(uploadParamsVO);
  302. }
  303. //简单同族 OS_PATENT_SIMPLEFAMILY
  304. patentSimplyFamilyBusiness(uploadParamsVO);
  305. //发明人 OS_PATENT_INVENTOR
  306. patentInventorBusiness(uploadParamsVO);
  307. //申请人(原始)/权利人(当前) OS_PATENT_APPLICATION || OS_APPLICATION_ATTR
  308. patentApplicationBusiness(uploadParamsVO);
  309. //申请人地址 OS_PATENT_APPLICATION
  310. patentApplicationAddressBusiness(uploadParamsVO);
  311. //分类号关联 OS_PATENT_TYPENO
  312. patentTypeNoBusiness(uploadParamsVO);
  313. //事务信息 OS_PATENT_AFFAIR
  314. patentAffairBusiness(uploadParamsVO);
  315. } catch (Exception e) {
  316. e.printStackTrace();
  317. if (uploadParamsVO.getPatent() != null) {
  318. ImportErrorLog importErrorLog = new ImportErrorLog();
  319. importErrorLog.setPatentId(uploadParamsVO.getPatent().getId())
  320. .setPatentNo(uploadParamsVO.getPatent().getPatentNo())
  321. .setCreateTime(new SimpleDateFormat("yyyy-MM-dd 24HI:mm:ss").format(new Date()))
  322. .setCreateUserId(Integer.parseInt(params.getUserId()))
  323. .setMistakeMessage(e.getMessage())
  324. .setProjectId(params.getProjectId());
  325. importErrorLogMapper.insert(importErrorLog);
  326. FLAG += 1;
  327. }
  328. TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
  329. }
  330. }
  331. /**
  332. * @param uploadParamsVO 全局类
  333. * @date 2022-7-11
  334. * @name 工具方法
  335. * @description 查询数据是否存在 如果存在 返回该条数据 如果不存在 新增一条数据
  336. */
  337. private void getOneOrInsertOne(UploadParamsVO uploadParamsVO) {
  338. if (uploadParamsVO.getPatent() != null) {
  339. uploadParamsVO.getPatent().setPatentNo(uploadParamsVO.getPatent().getPatentNo().trim());
  340. //用专利号查询该条数据是否存在
  341. Patent patent = patentService.getByPatentNo(uploadParamsVO.getPatent().getPatentNo());
  342. //如果不存在就新增一条
  343. if (patent == null) {
  344. uploadParamsVO.getPatent().insert();
  345. } else {
  346. uploadParamsVO.getPatent().setId(patent.getId());
  347. }
  348. }
  349. }
  350. private void patentRightBusiness(UploadParamsVO uploadParamsVO) {
  351. PatentRightParams patentRightParams = new PatentRightParams();
  352. patentRightParams.setPatentId(uploadParamsVO.getPatent().getId());
  353. patentRightParams.setPatentNo(uploadParamsVO.getPatent().getPatentNo());
  354. if (uploadParamsVO.getPatentRight() != null) {
  355. patentRightParams.setContent(uploadParamsVO.getPatentRight().getContent());
  356. patentRightParams.setContentOut(uploadParamsVO.getPatentRight().getContentOut());
  357. }
  358. if (uploadParamsVO.getSelfContent() != null) {
  359. patentRightParams.setSelfContent(uploadParamsVO.getSelfContent());
  360. }
  361. patentRightService.updatePatentRight(patentRightParams);
  362. patentRightService.importAuthority(patentRightParams);
  363. }
  364. private void patentInstructionTextBusiness(UploadParamsVO uploadParamsVO) {
  365. PatentInstructionTextParams patentInstructionTextParams = new PatentInstructionTextParams();
  366. patentInstructionTextParams.setPatentId(uploadParamsVO.getPatent().getId());
  367. patentInstructionTextParams.setManual(uploadParamsVO.getPatentInstructionText().getManual());
  368. patentInstructionTextParams.setManualOut(uploadParamsVO.getPatentInstructionText().getManualOut());
  369. patentInstructionTextService.updatePatentInstructionText(patentInstructionTextParams);
  370. }
  371. //代理人
  372. private void patentAgentBusiness(UploadParamsVO uploadParamsVO) {
  373. PatentAgentParams patentAgentParams = new PatentAgentParams();
  374. patentAgentParams.setPatentId(uploadParamsVO.getPatent().getId());
  375. List<String> agentList = uploadParamsVO.getPatentAgentList().stream().map(PatentAgent::getName).collect(Collectors.toList());
  376. patentAgentParams.setAgent(agentList);
  377. patentAgentService.updatePatentAgent(patentAgentParams);
  378. }
  379. //质押质权人 OS_PATENT_PLEDGE
  380. private void patentPledgeBusiness(UploadParamsVO uploadParamsVO) {
  381. PatentPledgeParams patentPledgeParams = new PatentPledgeParams();
  382. patentPledgeParams.setPatentId(uploadParamsVO.getPatent().getId());
  383. List<String> pledgeeList = uploadParamsVO.getPatentPledgeList().stream().map(PatentPledge::getPledgee).collect(Collectors.toList());
  384. List<String> pledgorList = uploadParamsVO.getPatentPledgeList().stream().map(PatentPledge::getPledgor).collect(Collectors.toList());
  385. patentPledgeParams.setPledgee(pledgeeList);
  386. patentPledgeParams.setPledgor(pledgorList);
  387. patentPledgeService.updatePatentPledge(patentPledgeParams);
  388. }
  389. //许可人 OS_PATENT_LICENSOR
  390. private void patentLicensorBusiness(UploadParamsVO uploadParamsVO) {
  391. PatentLicensorParams patentLicensorParams = new PatentLicensorParams();
  392. patentLicensorParams.setPatentId(uploadParamsVO.getPatent().getId());
  393. List<String> licensorList = uploadParamsVO.getPatentLicensorList().stream().map(PatentLicensor::getLicensor).collect(Collectors.toList());
  394. List<String> licenseeList = uploadParamsVO.getPatentLicensorList().stream().map(PatentLicensor::getLicensee).collect(Collectors.toList());
  395. List<String> typeList = uploadParamsVO.getPatentLicensorList().stream().map(PatentLicensor::getType).collect(Collectors.toList());
  396. patentLicensorParams.setLicensor(licensorList);
  397. patentLicensorParams.setLicensee(licenseeList);
  398. patentLicensorParams.setType(typeList);
  399. patentLicensorService.updatePatentLicensor(patentLicensorParams);
  400. }
  401. //简单同族
  402. private void patentSimplyFamilyBusiness(UploadParamsVO uploadParamsVO) {
  403. PatentSimpleFamilyParams patentSimpleFamilyParams = new PatentSimpleFamilyParams();
  404. if (uploadParamsVO.getSimpleFamily() != null) {
  405. patentSimpleFamilyParams.setSimpleFamily(uploadParamsVO.getSimpleFamily());
  406. }
  407. if (uploadParamsVO.getPatSnapFamily() != null) {
  408. patentSimpleFamilyParams.setPatSnapFamily(uploadParamsVO.getPatSnapFamily());
  409. }
  410. if (uploadParamsVO.getInpadocFamily() != null) {
  411. patentSimpleFamilyParams.setInpadocFamily(uploadParamsVO.getInpadocFamily());
  412. }
  413. patentSimpleFamilyParams.setPatentId(uploadParamsVO.getPatent().getId());
  414. patentSimpleFamilyParams.setPatentNo(uploadParamsVO.getPatent().getPatentNo());
  415. patentSimpleFamilyService.updatePatentSimpleFamily(patentSimpleFamilyParams);
  416. }
  417. //发明人 OS_PATENT_INVENTOR
  418. private void patentInventorBusiness(UploadParamsVO uploadParamsVO) {
  419. PatentInventorParams patentInventorParams = new PatentInventorParams();
  420. if (uploadParamsVO.getPatentInventorList() != null) {
  421. List<String> addressList = uploadParamsVO.getPatentInventorList().stream().map(PatentInventor::getAddress).filter(Objects::nonNull).collect(Collectors.toList());
  422. patentInventorParams.setAddressList(addressList);
  423. List<String> nameList = uploadParamsVO.getPatentInventorList().stream().map(PatentInventor::getName).collect(Collectors.toList());
  424. patentInventorParams.setNameList(nameList);
  425. }
  426. if (uploadParamsVO.getFirstName() != null) {
  427. patentInventorParams.setFirstName(uploadParamsVO.getFirstName());
  428. }
  429. if (uploadParamsVO.getFirstAddress() != null) {
  430. patentInventorParams.setFirstAddress(uploadParamsVO.getFirstAddress());
  431. }
  432. patentInventorParams.setPatentId(uploadParamsVO.getPatent().getId());
  433. patentInventorService.updatePatentInventor(patentInventorParams);
  434. }
  435. //申请人(原始)/权利人(当前) OS_PATENT_APPLICATION || OS_APPLICATION_ATTR
  436. private void patentApplicationBusiness(UploadParamsVO uploadParamsVO) {
  437. // 根据本条数据的名字查询所有的申请人信息
  438. List<String> name = new ArrayList<>();
  439. if (uploadParamsVO.getPatentApplicantCurrentName() != null) {
  440. name.addAll(uploadParamsVO.getPatentApplicantCurrentName());
  441. }
  442. if (uploadParamsVO.getPatentApplicantOriginalName() != null) {
  443. name.addAll(uploadParamsVO.getPatentApplicantOriginalName());
  444. }
  445. if (uploadParamsVO.getPatentApplicantStandardCurrentName() != null) {
  446. name.addAll(uploadParamsVO.getPatentApplicantStandardCurrentName());
  447. }
  448. if (uploadParamsVO.getPatentApplicantStandardOriginalName() != null) {
  449. name.addAll(uploadParamsVO.getPatentApplicantStandardOriginalName());
  450. }
  451. if (name.size() != 0) {
  452. List<PatentApplicant> patentApplicantList = patentApplicantService.list(Wrappers.<PatentApplicant>lambdaQuery().in(PatentApplicant::getName, name));
  453. //权利人
  454. if (uploadParamsVO.getPatentApplicantCurrentName() != null || uploadParamsVO.getPatentApplicantStandardCurrentName() != null)
  455. patentApplicantLinkService.updatePatentApplicantLink(uploadParamsVO.getPatentApplicantCurrentName(), uploadParamsVO.getPatentApplicantStandardCurrentName(), 1, uploadParamsVO.getPatent().getId(), patentApplicantList);
  456. //申请人
  457. if (uploadParamsVO.getPatentApplicantOriginalName() != null || uploadParamsVO.getPatentApplicantStandardOriginalName() != null)
  458. patentApplicantLinkService.updatePatentApplicantLink(uploadParamsVO.getPatentApplicantOriginalName(), uploadParamsVO.getPatentApplicantStandardOriginalName(), 2, uploadParamsVO.getPatent().getId(), patentApplicantList);
  459. }
  460. }
  461. private void patentApplicationAddressBusiness(UploadParamsVO uploadParamsVO) {
  462. PatentApplicantAddressParams patentApplicantAddressParams = new PatentApplicantAddressParams();
  463. patentApplicantAddressParams.setPatentId(uploadParamsVO.getPatent().getId());
  464. patentApplicantAddressParams.setCurrentAddress(uploadParamsVO.getPatentApplicantCurrentAddress());
  465. patentApplicantAddressParams.setOriginalAddress(uploadParamsVO.getPatentApplicantOriginalAddress());
  466. patentApplicantAddressParams.setCurrentCountry(uploadParamsVO.getPatentApplicantCurrentCountry());
  467. patentApplicantAddressParams.setOriginalCountry(uploadParamsVO.getPatentApplicantOriginalCountry());
  468. patentApplicantAddressParams.setFirstCurrentAddress(uploadParamsVO.getFirstAddress());
  469. patentApplicantService.updatePatentApplicantAddress(patentApplicantAddressParams);
  470. }
  471. private void patentThematicPidBusiness(UploadParamsVO uploadParamsVO, ProjectImportPatentVO projectImportPatentVO) {
  472. projectPatentLinkService.updateProjectPatent(projectImportPatentVO.getProjectId(), uploadParamsVO.getPatent().getId());
  473. }
  474. private void patentProjectFieldPatentLinkBusiness(UploadParamsVO uploadParamsVO, ProjectImportPatentVO projectImportPatentVO) {
  475. projectFieldPatentLinkService.updateProjectFieldPatentLink(projectImportPatentVO, uploadParamsVO.getPatent().getId());
  476. }
  477. private void patentProjectFolderPatentLinkBusiness(UploadParamsVO uploadParamsVO, ProjectImportPatentVO projectImportPatentVO) {
  478. projectFolderPatentLinkService.updateProjectFolderLink(projectImportPatentVO, uploadParamsVO.getPatent().getId());
  479. }
  480. private void patentLabelBusiness(UploadParamsVO uploadParamsVO, ProjectImportPatentVO projectImportPatentVO) {
  481. PatentLabelParams patentLabelParams = new PatentLabelParams();
  482. patentLabelParams.setPatentId(uploadParamsVO.getPatent().getId());
  483. patentLabelParams.setProjectId(projectImportPatentVO.getProjectId());
  484. List<String> labelList = uploadParamsVO.getPatentLabelList().stream().map(PatentLabel::getName).collect(Collectors.toList());
  485. patentLabelParams.setLabel(labelList);
  486. patentLabelService.updatePatentLabel(patentLabelParams);
  487. }
  488. private void patentTypeNoBusiness(UploadParamsVO uploadParamsVO) {
  489. PatentClassNumberParams patentClassNumberParams = new PatentClassNumberParams();
  490. if (uploadParamsVO.getMainIpc() != null) {
  491. patentClassNumberParams.setMainIpc(uploadParamsVO.getMainIpc());
  492. }
  493. if (uploadParamsVO.getMainUpc() != null) {
  494. patentClassNumberParams.setMainUpc(uploadParamsVO.getMainUpc());
  495. }
  496. if (uploadParamsVO.getCpcList() != null) {
  497. patentClassNumberParams.setCpcList(uploadParamsVO.getCpcList());
  498. }
  499. if (uploadParamsVO.getLocList() != null) {
  500. patentClassNumberParams.setLocList(uploadParamsVO.getLocList());
  501. }
  502. if (uploadParamsVO.getUpcList() != null) {
  503. patentClassNumberParams.setUpcList(uploadParamsVO.getUpcList());
  504. }
  505. if (uploadParamsVO.getIpcList() != null) {
  506. patentClassNumberParams.setIpcList(uploadParamsVO.getIpcList());
  507. }
  508. patentClassNumberParams.setPatentId(uploadParamsVO.getPatent().getId());
  509. patentClassNumberLinkService.updatePatentClassNumberLink(patentClassNumberParams);
  510. }
  511. private void patentAffairBusiness(UploadParamsVO uploadParamsVO) {
  512. PatentAffairParams patentAffairParams = new PatentAffairParams();
  513. if (uploadParamsVO.getPatentAffair() != null) {
  514. patentAffairParams.setContent(uploadParamsVO.getPatentAffair().getContent());
  515. patentAffairParams.setStatusList(uploadParamsVO.getPatentAffair().getStatus());
  516. patentAffairParams.setDateTime(uploadParamsVO.getPatentAffair().getDateTime());
  517. }
  518. if (uploadParamsVO.getSimpleStatus() != null) {
  519. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Collections.singletonList(Constants.PATENT_SIMPLE_STATUS));
  520. Integer simpleStatus = Integer.parseInt(systemDictList.stream()
  521. .filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getLabel().equals(uploadParamsVO.getSimpleStatus()))
  522. .findFirst()
  523. .orElse(new SystemDict()).getValue());
  524. patentAffairParams.setSimpleStatus(simpleStatus);
  525. }
  526. patentAffairParams.setPatentId(uploadParamsVO.getPatent().getId());
  527. patentAffairService.updatePatientAffair(patentAffairParams);
  528. }
  529. private void patentFieldBusiness(TaskParams params, UploadParamsVO uploadParamsVO, ProjectImportPatentVO projectImportPatentVO) {
  530. PatentCustomFieldParams patentCustomFieldParams = new PatentCustomFieldParams();
  531. for (int i = 0; i < uploadParamsVO.getCustomerFieldList().size(); i++) {
  532. patentCustomFieldParams.setPatentId(uploadParamsVO.getPatent().getId());
  533. patentCustomFieldParams.setProjectId(projectImportPatentVO.getProjectId());
  534. patentCustomFieldParams.setUserId(Integer.parseInt(params.getUserId()));
  535. patentCustomFieldParams.put(uploadParamsVO.getCustomerFieldList().get(i).getKey(), uploadParamsVO.getCustomerFieldList().get(i).getFieldList());
  536. }
  537. patentService.updatePatentCustomField(patentCustomFieldParams);
  538. }
  539. @Async("singleThreadAsyncTaskExecutor")
  540. public void uploadPatentForProduct(TaskParams params, Integer productId) {
  541. Integer total = params.getRowList().size();
  542. try {
  543. //先解析Json文件 获得配置文件的Json串
  544. String getSettingJson = fileUtils.analysisJsonFile();
  545. //查找需求数据源的对应配置
  546. List<UploadSettingVO.Column> jsonData = UploadPatentBatchUtil.parsingConfigurationFilesBro(getSettingJson);
  547. Map<String, PictureData> pictureDataMap = ExcelUtils.getDataFromExcel(params.getPath());
  548. //将数据进行装配并进行数据库操作
  549. for (int i = 0; i < params.getRowList().size(); i++) {
  550. //获取每一行的数据
  551. Map<Object, Object> row = params.getRowList().get(i);
  552. //基础数据装配
  553. UploadParamsVO uploadParamsVO = UploadPatentBatchUtil.processData(row, jsonData);
  554. //查询数据是否存在 如果存在 返回该条数据 如果不存在 新增一条数据
  555. getOneOrInsertOne(uploadParamsVO);
  556. //专利信息需要特殊处理部分
  557. //专利信息(摘要附图)数据装配
  558. PictureData pictureData = pictureDataMap.get(String.valueOf(i + 1));
  559. if (uploadParamsVO.getPatent() != null) {
  560. if (uploadParamsVO.getPatent().getId() != null && pictureData != null) {
  561. uploadParamsVO.getPatent().setAbstractPath(patentImageService.updatePatentImage(uploadParamsVO.getPatent().getId(), pictureData));
  562. }
  563. }
  564. //专利信息(代理机构)数据装配
  565. if (uploadParamsVO.getPatent() != null) {
  566. if (uploadParamsVO.getPatent().getAgencyId() != null) {
  567. uploadParamsVO.getPatent().setAgencyId(patentAgencyService.getAgencyStringIdByName(uploadParamsVO.getPatent().getAgencyId()));
  568. }
  569. }
  570. //将装配对象中的数据保存到数据库
  571. dataToDBBro(params, uploadParamsVO);
  572. //添加关联关系
  573. assoProductPatentService.addPatents(Arrays.asList(uploadParamsVO.getPatent().getPatentNo()), productId);
  574. //通过WebSocket 在每一次循环结束后 向前端发送完成进度
  575. WebSocketServer.sendInfo(Response.websocket(new TaskWebSocketDTO()
  576. .setTaskId(params.getTaskId())
  577. .setComplete(false)
  578. .setIndex(i)
  579. .setTaskType(Constants.TASK_IMPORT_PATENT)
  580. .setPercentage(total == 0 ? 0 : Math.round((total.equals(i) ? (i * 1D) : (i + 1D)) / total * 100D))
  581. .setFileName("")
  582. .setOldName(params.getOldName())
  583. .setUrl("")
  584. .setTotal(total), ResponseEnum.PATENT_IMPORT_TASK_SUCCESS), params.getUserId());
  585. }
  586. SpringUtil.getBean(ProjectService.class).setImportPatentTaskStatus(2, params.getTaskId());
  587. WebSocketServer.sendInfo(Response.websocket(new TaskWebSocketDTO()
  588. .setTaskId(params.getTaskId())
  589. .setComplete(true)
  590. .setIndex(total)
  591. .setTaskType(Constants.TASK_IMPORT_PATENT)
  592. .setPercentage(100L)
  593. .setFileName("")
  594. .setOldName(params.getOldName())
  595. .setUrl("")
  596. .setTotal(total), ResponseEnum.PATENT_IMPORT_TASK_SUCCESS), params.getUserId());
  597. } catch (Exception e) {
  598. e.printStackTrace();
  599. SpringUtil.getBean(ProjectService.class).setImportPatentTaskStatus(3, params.getTaskId());
  600. if (FLAG > 0) {
  601. int successCount = total - FLAG;
  602. WebSocketServer.sendInfo(Response.error("部分数据上传成功" + "\n" + "成功条数:" + successCount + "失败条数:" + FLAG), params.getUserId());
  603. }
  604. FLAG = 0;
  605. }
  606. }
  607. /**
  608. * @date 2022-7-11
  609. * @name 数据库交互
  610. * @description 将装配完毕的VO类向数据库中不同的表进行添加或修改操作(dataToDB兄弟类)
  611. */
  612. @Transactional(rollbackFor = Exception.class)
  613. public String dataToDBCell(PatentCell patentCell) throws ParseException {
  614. UploadParamsVO uploadParamsVO = new UploadParamsVO();
  615. Patent patent =new Patent();
  616. //设置专利号
  617. patent.setPatentNo(patentCell.getPatentNo());
  618. //设置摘要
  619. patent.setAbstractStr(patentCell.getAbstrText());
  620. //设置标题
  621. patent.setName(patentCell.getTitle());
  622. //设置公开日
  623. SimpleDateFormat simpleDateFormat = new SimpleDateFormat("yyyy.MM.dd");
  624. if(patentCell.getPubilcDate()!=null) {
  625. Date date = simpleDateFormat.parse(patentCell.getPubilcDate());
  626. Integer ts = (int) date.getTime();
  627. patent.setPublicDate(ts);
  628. }
  629. //设置申请号
  630. patent.setApplicationNo(patentCell.getApplicationNo());
  631. //设置申请日
  632. if(patentCell.getApplicationDate()!=null) {
  633. Date date = simpleDateFormat.parse(patentCell.getApplicationDate());
  634. Integer ts = (int) date.getTime();
  635. patent.setApplicationDate(ts);
  636. }
  637. //设置摘要附图
  638. patent.setAbstractPath(patentCell.getPicUrl());
  639. //设置pdf文档
  640. patentInstructionService.edit( patentCell.getPatentNo(),patentCell.getPdf());
  641. //设置公开号
  642. patent.setPublicNo(patentCell.getPublicNo());
  643. uploadParamsVO.setSimpleStatus(patentCell.getStatue());
  644. uploadParamsVO.setPatent(patent);
  645. getOneOrInsertOne(uploadParamsVO);
  646. //装载代理机构
  647. if (patentCell.getAgency() != null) {
  648. uploadParamsVO.getPatent().setAgencyId(patentAgencyService.getAgencyStringIdByName(patentCell.getAgency()));
  649. }
  650. try {
  651. //专利信息 OS_PATENT
  652. if (uploadParamsVO.getPatent() != null) {
  653. List<SystemDict> systemDictList = systemDictService.getSystemDictListByType(Collections.singletonList(Constants.PATENT_SIMPLE_STATUS));
  654. Integer simpleStatus = Integer.parseInt(systemDictList.stream()
  655. .filter(systemDict -> systemDict.getType().equals(Constants.PATENT_SIMPLE_STATUS) && systemDict.getLabel().equals(uploadParamsVO.getPatentSimpleStatus()))
  656. .findFirst()
  657. .orElse(new SystemDict()).getValue());
  658. uploadParamsVO.getPatent().setSimpleStatus(simpleStatus);
  659. uploadParamsVO.getPatent().updateById();
  660. }
  661. uploadParamsVO.setPatentRight(new PatentRight());
  662. uploadParamsVO.getPatentRight().setContent(StringUtils.join(patentCell.getRights(), ""));
  663. uploadParamsVO.setSelfContent(patentCell.getMainRignt());
  664. //权利要求 OS_PATENT_RIGHT
  665. patentRightBusiness(uploadParamsVO);
  666. //说明书(文本) OS_PATENT_INSTRUCTION_TEXT
  667. uploadParamsVO.setPatentInstructionText(new PatentInstructionText());
  668. uploadParamsVO.getPatentInstructionText().setManual(patentCell.getPatentInstructionText());
  669. if (uploadParamsVO.getPatentInstructionText() != null) {
  670. patentInstructionTextBusiness(uploadParamsVO);
  671. }
  672. //发明人 OS_PATENT_INVENTOR
  673. if(patentCell.getInventors().size()!=0) {
  674. PatentInventorParams patentInventorParams = new PatentInventorParams();
  675. patentInventorParams.setPatentId(uploadParamsVO.getPatent().getId());
  676. patentInventorParams.setNameList(patentCell.getInventors());
  677. patentInventorParams.setAddressList(new ArrayList<>());
  678. patentInventorService.updatePatentInventor(patentInventorParams);
  679. }
  680. //申请人(原始)/权利人(当前) OS_PATENT_APPLICATION || OS_APPLICATION_ATTR
  681. uploadParamsVO.setPatentApplicantCurrentName(patentCell.getApplicationCurrents());
  682. uploadParamsVO.setPatentApplicantOriginalName(patentCell.getApplicationPersons());
  683. patentApplicationBusiness(uploadParamsVO);
  684. //申请人地址 OS_PATENT_APPLICATION
  685. uploadParamsVO.setPatentApplicantOriginalAddress(patentCell.getApplicationAddress());
  686. patentApplicationAddressBusiness(uploadParamsVO);
  687. //分类号关联 OS_PATENT_TYPENO
  688. uploadParamsVO.setIpcList(patentCell.getIpc());
  689. uploadParamsVO.setMainIpc(patentCell.getMainIpc());
  690. patentTypeNoBusiness(uploadParamsVO);
  691. //代理人 OS_PATENT_AGENT
  692. if(patentCell.getAgencyPersons()!=null&&patentCell.getAgencyPersons().size()!=0) {
  693. PatentAgentParams patentAgentParams = new PatentAgentParams();
  694. patentAgentParams.setPatentId(uploadParamsVO.getPatent().getId());
  695. patentAgentParams.setAgent(patentCell.getAgencyPersons());
  696. patentAgentService.updatePatentAgent(patentAgentParams);
  697. }
  698. //事务信息 OS_PATENT_AFFAIR
  699. if(patentCell.getPatentAffairs()!=null&&patentCell.getPatentAffairs().size()>0) {
  700. patentAffairService.updatePatientAffairs(patentCell.getPatentAffairs(), uploadParamsVO.getPatent().getId());
  701. }
  702. //当专题库id不为null时添加专利到专题库
  703. if(patentCell.getProjectId()!=null){
  704. projectPatentLinkService.updateProjectPatent(patentCell.getProjectId(),uploadParamsVO.getPatent().getId());
  705. }
  706. return Response.success();
  707. } catch (Exception e) {
  708. e.printStackTrace();
  709. if (uploadParamsVO.getPatent() != null) {
  710. ImportErrorLog importErrorLog = new ImportErrorLog();
  711. importErrorLog.setPatentId(uploadParamsVO.getPatent().getId())
  712. .setPatentNo(uploadParamsVO.getPatent().getPatentNo())
  713. .setCreateTime(new SimpleDateFormat("yyyy-MM-dd 24HI:mm:ss").format(new Date()));
  714. // .setCreateUserId(Integer.parseInt(params.getUserId()))
  715. // .setMistakeMessage(e.getMessage())
  716. // .setProjectId(params.getProjectId());
  717. importErrorLogMapper.insert(importErrorLog);
  718. FLAG += 1;
  719. }
  720. TransactionAspectSupport.currentTransactionStatus().setRollbackOnly();
  721. return Response.error();
  722. }
  723. }
  724. }