talk_to_friend_task_result_notice.go 1.8 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162
  1. package MessageHandlers
  2. import (
  3. "context"
  4. "encoding/json"
  5. "fmt"
  6. "github.com/zeromicro/go-zero/core/logx"
  7. "wechat-api/ent/contact"
  8. "wechat-api/internal/pkg/wechat_ws"
  9. "wechat-api/internal/svc"
  10. )
  11. type TalkToFriendTaskResultNoticeHandler struct {
  12. svcCtx *svc.ServiceContext
  13. }
  14. func NewTalkToFriendTaskResultNoticeHandler(svcCtx *svc.ServiceContext) *TalkToFriendTaskResultNoticeHandler {
  15. return &TalkToFriendTaskResultNoticeHandler{
  16. svcCtx: svcCtx,
  17. }
  18. }
  19. type TalkToFriendTaskResultNoticeMessage struct {
  20. Success bool `json:"success"` // 是否成功
  21. Code string `json:"code"` // 错误码 Success = true 忽略
  22. ErrMsg string `json:"errMsg"` // 错误内容描述 Success = true 忽略
  23. WeChatId string `json:"weChatId"` // 执行的微信
  24. FriendId string `json:"friendId"` // 执行的用户对象
  25. MsgId string `json:"msgId"` // 聊天Id
  26. MsgSvrId int64 `json:"msgSvrId"` //
  27. CreateTime int64 `json:"createTime"` // 消息发送时间
  28. }
  29. func (f *TalkToFriendTaskResultNoticeHandler) Handler(msg *wechat_ws.MsgJsonObject) error {
  30. if msg.MsgType == "TalkToFriendTaskResultNotice" {
  31. logx.Info("msg 的内容是:%s", msg)
  32. message := TalkToFriendTaskResultNoticeMessage{}
  33. err := json.Unmarshal([]byte(msg.Message), &message)
  34. if err != nil {
  35. return err
  36. }
  37. logx.Info("msg.Message 的内容是:%s", message)
  38. friendId, _ := f.svcCtx.Rds.Get(context.TODO(), fmt.Sprintf("MsgId_FriendId:%s", message.MsgId)).Result()
  39. if friendId == "" {
  40. return nil
  41. }
  42. if message.Code == "InternalError" {
  43. err = f.svcCtx.DB.Contact.
  44. Update().
  45. Where(contact.WxWxidEQ(message.WeChatId), contact.WxidEQ(friendId)).
  46. SetStatus(2).
  47. Exec(context.TODO())
  48. if err != nil {
  49. return err
  50. }
  51. }
  52. }
  53. return nil
  54. }