websocket_msg.go 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. package services
  2. import (
  3. "eta/eta_api/models"
  4. "eta/eta_api/services/data"
  5. "eta/eta_api/utils"
  6. "github.com/gorilla/websocket"
  7. )
  8. func DealWebSocketMsg(conn *websocket.Conn, adminId int) {
  9. DealEdbInspectionMessage(conn, adminId)
  10. }
  11. // 处理巡检消息
  12. func DealEdbInspectionMessage(conn *websocket.Conn, adminId int) {
  13. messageList, err := data.GetHistoryInspectionMessages(adminId)
  14. if err != nil {
  15. utils.FileLog.Error("获取巡检信息历史失败,err:%s, adminId:%d", err.Error(), adminId)
  16. return
  17. }
  18. success := make(chan int64, 10)
  19. go func() {
  20. defer close(success)
  21. for i, msg := range messageList {
  22. if i == 0 {
  23. // 多条消息仅发送最新一条
  24. respData, err := data.SendInspectionMessages(adminId, msg)
  25. if err != nil {
  26. utils.FileLog.Error("巡检信息发送失败,err:%s, adminId:%d", err.Error(), adminId)
  27. } else {
  28. resp := models.WebsocketMessageResponse{
  29. MessageType: 1,
  30. Data: respData,
  31. }
  32. err = conn.WriteJSON(resp)
  33. if err != nil {
  34. utils.FileLog.Error("巡检信息发送失败,err:%s, adminId:%d", err.Error(), adminId)
  35. } else {
  36. utils.FileLog.Info("巡检信息发送成功,adminId:%d, messageId:%d", adminId, msg.MessageId)
  37. success <- msg.MessageId
  38. }
  39. }
  40. } else {
  41. success <- msg.MessageId
  42. }
  43. }
  44. }()
  45. go func() {
  46. readList := make([]int64, 0)
  47. for {
  48. msgId, ok := <-success
  49. if !ok {
  50. break
  51. }
  52. readList = append(readList, msgId)
  53. }
  54. _, err = data.ReadEdbInspectionMessageList(readList, adminId)
  55. if err != nil {
  56. utils.FileLog.Error("巡检信息已读失败,err:%s, adminId:%d", err.Error(), adminId)
  57. }
  58. }()
  59. }