fix.go 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178
  1. package pcsg
  2. import (
  3. "encoding/json"
  4. "errors"
  5. "eta/eta_email_analysis/global"
  6. "eta/eta_email_analysis/models/eta"
  7. "eta/eta_email_analysis/models/report"
  8. "eta/eta_email_analysis/utils"
  9. "eta/eta_email_analysis/utils/mail"
  10. "fmt"
  11. "github.com/emersion/go-imap"
  12. "github.com/emersion/go-imap/client"
  13. "log"
  14. "strings"
  15. )
  16. func Fix() {
  17. mailAddress := fmt.Sprintf("%s:%d", global.CONFIG.Email.Host, global.CONFIG.Email.Port)
  18. // 建立与 IMAP 服务器的连接
  19. c, err := client.DialTLS(mailAddress, nil)
  20. if err != nil {
  21. fmt.Printf("连接 IMAP 服务器失败: %+v \n", err)
  22. return
  23. }
  24. // 最后一定不要忘记退出登录
  25. defer func() {
  26. _ = c.Logout()
  27. }()
  28. // 登录
  29. if err = c.Login(global.CONFIG.Email.UserName, global.CONFIG.Email.Password); err != nil {
  30. fmt.Printf("邮箱[%s] 登录失败: %v \n", fmt.Sprintf("%s:%s", global.CONFIG.Email.UserName, mailAddress), err)
  31. return
  32. }
  33. // 列出当前邮箱中的文件夹
  34. mailboxes := make(chan *imap.MailboxInfo, 10)
  35. done := make(chan error, 1) // 记录错误的 chan
  36. go func() {
  37. done <- c.List("", "*", mailboxes)
  38. }()
  39. log.Println("-->当前邮箱的文件夹 Mailboxes:")
  40. var folderExists bool
  41. for m := range mailboxes {
  42. log.Println("* ", m.Name)
  43. if m.Name == global.CONFIG.Email.Folder {
  44. folderExists = true
  45. }
  46. }
  47. err = <-done
  48. if err != nil {
  49. global.LOG.Errorf("列出邮箱列表时,出现错误:%v \n", err)
  50. return
  51. }
  52. log.Println("-->列出邮箱列表完毕!")
  53. if !folderExists {
  54. err = errors.New(fmt.Sprintf("文件夹[%s] 不存在 \n", global.CONFIG.Email.Folder))
  55. return
  56. }
  57. // 选择指定的文件夹
  58. mbox, err := c.Select(global.CONFIG.Email.Folder, false)
  59. if err != nil {
  60. err = errors.New(fmt.Sprintf("选择邮件箱失败: %+v", err))
  61. return
  62. }
  63. //log.Printf("mbox %+v \n", mbox)
  64. log.Printf("当前文件夹[%s]中,总共有 %d 封邮件 \n", global.CONFIG.Email.Folder, mbox.Messages)
  65. if mbox.Messages == 0 {
  66. //log.Fatalf("当前文件夹[%s]中没有邮件", folder)
  67. return
  68. }
  69. list, err := report.GetNoSysUserNameOutsideReport()
  70. if err != nil {
  71. fmt.Println("获取没有用户的信息失败:", err)
  72. return
  73. }
  74. for _, v := range list {
  75. _, fromName, tmpErr := mail.ListenMailV2(c, v.EmailMessageUID)
  76. if tmpErr != nil {
  77. fmt.Println(v.Title, ",获取失败:", tmpErr)
  78. continue
  79. }
  80. v.SysUserName = fromName
  81. tmpErr = v.Update([]string{"SysUserName"})
  82. if tmpErr != nil {
  83. fmt.Println(v.Title, ",更新信息失败:", tmpErr)
  84. continue
  85. }
  86. }
  87. }
  88. func FixHistory() {
  89. list, err := report.GetMailOutsideReport()
  90. if err != nil {
  91. fmt.Println("获取没有分类的信息失败:", err)
  92. return
  93. }
  94. ruleJson, err := eta.GetBusinessConfByKey("MailCheckRule")
  95. if err != nil {
  96. global.FILE_LOG.Error("获取规则配置失败:%v", err)
  97. return
  98. }
  99. var ruleList []report.MailRule
  100. err = json.Unmarshal([]byte(ruleJson.ConfVal), &ruleList)
  101. if err != nil {
  102. global.FILE_LOG.Error("解析规则配置失败:%v", err)
  103. return
  104. }
  105. ruleMap := make(map[string]report.MailRule)
  106. for _, v := range ruleList {
  107. ruleMap[v.Rule] = v
  108. }
  109. classifyAll, e := report.GetClassifyAll()
  110. if e != nil {
  111. err = e
  112. global.FILE_LOG.Error("获取分类失败:", err)
  113. return
  114. }
  115. calssifyMap := make(map[int]*report.Classify)
  116. for _, v := range classifyAll {
  117. calssifyMap[v.Id] = v
  118. }
  119. for _, reportInfo := range list {
  120. for _, v := range ruleList {
  121. title := strings.ToLower(reportInfo.Title)
  122. rule := strings.ToLower(v.Rule)
  123. if strings.Contains(title, rule) {
  124. fmt.Println(reportInfo.Title, "匹配到规则:", v.Rule)
  125. reportInfo.Title = v.Title
  126. reportInfo.Abstract = v.Abstract
  127. reportInfo.ClassifyID = v.ClassifyId
  128. if calssifyMap[v.ClassifyId] != nil {
  129. reportInfo.ClassifyName = calssifyMap[v.ClassifyId].ClassifyName
  130. }
  131. if strings.Contains(v.Author, "@") {
  132. sysUser, tmpErr := eta.GetSysUserByEmail(v.Author)
  133. if tmpErr != nil && !utils.IsErrNoRow(tmpErr) {
  134. err = tmpErr
  135. return
  136. }
  137. if sysUser.AdminId > 0 {
  138. reportInfo.SysUserID = sysUser.AdminId
  139. reportInfo.SysUserName = sysUser.RealName
  140. } else {
  141. reportInfo.SysUserName = v.Author
  142. }
  143. } else {
  144. reportInfo.SysUserName = v.Author
  145. }
  146. err = reportInfo.Update([]string{"Title", "Abstract", "ClassifyID", "ClassifyName", "SysUserID", "SysUserName"})
  147. if err != nil {
  148. fmt.Println("更新失败:", err)
  149. return
  150. }
  151. fmt.Println(reportInfo.Title, "更新成功")
  152. }
  153. }
  154. if strings.Contains(reportInfo.Title, "[PCI ANALYTICS CLOUD PLATFORM(00) Fwd] - ") {
  155. reportInfo.Title = strings.Replace(reportInfo.Title, "[PCI ANALYTICS CLOUD PLATFORM(00) Fwd] - ", "", -1)
  156. err = reportInfo.Update([]string{"Title"})
  157. if err != nil {
  158. fmt.Println("更新失败:", err)
  159. return
  160. }
  161. fmt.Println(reportInfo.Title, "去除前缀成功")
  162. }
  163. }
  164. }