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