ParseEmailController.java 5.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142
  1. package com.simuwang.manage.api.email;
  2. import com.simuwang.base.common.support.MybatisPage;
  3. import com.simuwang.base.common.util.EncodeUtil;
  4. import com.simuwang.base.common.util.FileUtil;
  5. import com.simuwang.base.pojo.dto.query.EmailFileQuery;
  6. import com.simuwang.base.pojo.dto.query.EmailParseQuery;
  7. import com.simuwang.base.pojo.vo.*;
  8. import com.simuwang.daq.service.EmailParseApiService;
  9. import com.simuwang.logging.SystemLog;
  10. import com.simuwang.manage.service.ParseEmailService;
  11. import com.smppw.common.pojo.ResultVo;
  12. import com.smppw.common.pojo.enums.TimeRange;
  13. import jakarta.servlet.ServletOutputStream;
  14. import jakarta.servlet.http.HttpServletRequest;
  15. import jakarta.servlet.http.HttpServletResponse;
  16. import org.apache.commons.io.FileUtils;
  17. import org.apache.ibatis.annotations.Param;
  18. import org.slf4j.Logger;
  19. import org.slf4j.LoggerFactory;
  20. import org.springframework.beans.factory.annotation.Autowired;
  21. import org.springframework.web.bind.annotation.*;
  22. import java.io.File;
  23. import java.io.FileInputStream;
  24. import java.io.FileOutputStream;
  25. import java.io.IOException;
  26. import java.util.List;
  27. import java.util.Map;
  28. /**
  29. * 解析详情管理
  30. * Author: chenjianhua
  31. * Date: 2024/9/10 11:21
  32. * Description: ${DESCRIPTION}
  33. */
  34. @SystemLog(value = "解析详情管理")
  35. @RestController
  36. @RequestMapping("/v1/parse")
  37. public class ParseEmailController{
  38. private static final Logger logger = LoggerFactory.getLogger(ParseEmailController.class);
  39. @Autowired
  40. private ParseEmailService parseEmailService;
  41. @Autowired
  42. private EmailParseApiService emailParseApiService;
  43. /**
  44. * 保存邮件类型识别配置
  45. * @param emailTypeRuleVO
  46. * @return
  47. */
  48. @SystemLog(value = "保存邮件类型识别配置",type = SystemLog.Type.INSERT)
  49. @PostMapping("/save-email-type")
  50. public boolean saveEmailType(@RequestBody EmailTypeRuleVO emailTypeRuleVO){
  51. parseEmailService.saveEmailType(emailTypeRuleVO);
  52. return true;
  53. }
  54. /**
  55. * 查询邮件类型识别配置
  56. * @param
  57. * @return
  58. */
  59. @SystemLog(value = "查询邮件类型识别配置")
  60. @GetMapping("/search-email-type")
  61. public ResultVo searchEmailType(){
  62. EmailTypeRuleVO emailTypeRuleVO = parseEmailService.searchEmailType();
  63. return ResultVo.ok(emailTypeRuleVO);
  64. }
  65. /**
  66. * 解析页面展示查询
  67. * @param emailParseQuery
  68. * @return
  69. */
  70. @SystemLog(value = "解析页面展示查询")
  71. @GetMapping("/search-email-list")
  72. public MybatisPage<EmailParseInfoVO> searchEmailList(EmailParseQuery emailParseQuery){
  73. MybatisPage<EmailParseInfoVO> result = parseEmailService.searchEmailList(emailParseQuery);
  74. return result;
  75. }
  76. /**
  77. * 详情查询
  78. * @param emailFileQuery
  79. * @return
  80. */
  81. @SystemLog(value = "详情查询")
  82. @GetMapping("/detail")
  83. public MybatisPage<EmailFundNavCollectionVO> searchEmailDetail(EmailFileQuery emailFileQuery){
  84. MybatisPage<EmailFundNavCollectionVO> result = parseEmailService.searchEmailDetailById(emailFileQuery);
  85. return result;
  86. }
  87. /**
  88. * 解析邮件数据统计
  89. * @param timeRange Last1Week-近一周,Last1Month-近一个月,Last3Months-近三月,LastHalfYear-近半年,Last1Year-近一年,FromSetup-全部,Custom-自定义
  90. * @return
  91. */
  92. @SystemLog(value = "解析邮件数据统计")
  93. @GetMapping("/search-email-count")
  94. public ResultVo searchEmailCount(@RequestParam("timeRange") TimeRange timeRange,@RequestParam(value = "startDate",required = false)String startDate,@RequestParam(value = "endDate",required = false)String endDate){
  95. Map<String,Integer> result = parseEmailService.searchEmailCount(timeRange,startDate,endDate);
  96. return ResultVo.ok(result);
  97. }
  98. /**
  99. * 根据fileId下载邮件附件
  100. * @param fileId
  101. * @return
  102. */
  103. @SystemLog(value = "下载附件", type = SystemLog.Type.DOWNLOAD_OR_EXPORT)
  104. @PostMapping("/download-email-file")
  105. public void downloadEmailFile(@RequestBody FileIdVO fileId,HttpServletResponse response, HttpServletRequest request){
  106. try {
  107. EmailFileInfoVO emailFileInfoVO = parseEmailService.getEmailFileById(fileId.getFileId());
  108. response.setContentType("application/octet-stream");
  109. response.addHeader("Content-Disposition", "attachment;filename=" + EncodeUtil.encodeUTF8(emailFileInfoVO.getFileName()));
  110. ServletOutputStream outputStream = response.getOutputStream();
  111. FileUtils.copyFile(new File(emailFileInfoVO.getFilePath()),outputStream);
  112. outputStream.flush();
  113. outputStream.close();
  114. } catch (IOException e) {
  115. logger.error(e.getMessage(),e);
  116. }
  117. }
  118. /**
  119. * 根据邮件ID重新解析
  120. * @param idListVO
  121. * @return
  122. */
  123. @SystemLog(value = "根据邮件ID重新解析")
  124. @PostMapping("/reparse")
  125. public ResultVo reparse(@RequestBody IdListVO idListVO){
  126. for(Integer emailid : idListVO.getIdList()){
  127. emailParseApiService.reparseEmail(emailid);
  128. }
  129. return ResultVo.ok(true);
  130. }
  131. }