websocket_msg.go 1.6 KB

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