task_result_notice.go 2.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. package MessageHandlers
  2. import (
  3. "context"
  4. "encoding/json"
  5. "github.com/zeromicro/go-zero/core/logx"
  6. "strconv"
  7. "time"
  8. "wechat-api/ent/addwechatfriendlog"
  9. "wechat-api/internal/pkg/wechat_ws"
  10. "wechat-api/internal/svc"
  11. )
  12. type TaskResultNoticeHandler struct {
  13. svcCtx *svc.ServiceContext
  14. }
  15. func NewTaskResultNoticeHandler(svcCtx *svc.ServiceContext) *TaskResultNoticeHandler {
  16. return &TaskResultNoticeHandler{
  17. svcCtx: svcCtx,
  18. }
  19. }
  20. // Handle 实现 MessageHandlerStrategy 接口
  21. func (f *TaskResultNoticeHandler) Handle(ctx context.Context, msg *wechat_ws.MsgJsonObject, svcCtx *svc.ServiceContext) error {
  22. var messageTask TaskResultNoticeMessage
  23. logx.Infof("TaskResultNoticeMessage的内容是:%s", msg.Message)
  24. if err := json.Unmarshal([]byte(msg.Message), &messageTask); err != nil {
  25. logx.Errorf("预处理 JSON 失败: %v", err)
  26. return err
  27. }
  28. // 如果 TaskId 是字符串,就转换成数字
  29. var taskIdInt int64
  30. if messageTask.TaskId != nil {
  31. var err error
  32. taskIdInt, err = strconv.ParseInt(*messageTask.TaskId, 10, 64)
  33. if err != nil {
  34. logx.Errorf("Unmarshal.fail")
  35. return err
  36. }
  37. }
  38. if messageTask.TaskType != "AddFriendsTask" && messageTask.TaskType != "AddCustomerFromSearchTask" {
  39. logx.Infof("不是添加好友任务的回执")
  40. return nil
  41. }
  42. m, err := ParseJSONStringToMap(msg.Message)
  43. if err != nil {
  44. logx.Errorf("解析 JSON 失败: %v", err)
  45. return err
  46. }
  47. update := svcCtx.DB.AddWechatFriendLog.Update().
  48. Where(addwechatfriendlog.OwnerWxIDEQ(*messageTask.WeChatId)).
  49. Where(addwechatfriendlog.TaskIDEQ(taskIdInt)).
  50. //SetFindResult(m).
  51. SetAddResult(m).
  52. SetUpdatedAt(time.Now().Unix())
  53. if messageTask.Success {
  54. update.SetIsCanAdd(2)
  55. }
  56. if _, err := update.Save(ctx); err != nil {
  57. logx.Errorf("更新AddWechatFriendLog-field-add-result失败: %v", err)
  58. return err
  59. }
  60. return nil
  61. }
  62. type TaskResultNoticeMessage struct {
  63. Success bool `json:"Success,omitempty"` // 指针,便于判断字段是否存在
  64. Code *string `json:"Code,omitempty"` // 错误码
  65. ErrMsg *string `json:"ErrMsg,omitempty"` // 错误描述
  66. TaskId *string `json:"TaskId,omitempty"` // 任务ID(因前面问题,保持 string 类型)
  67. TaskType string `json:"TaskType,omitempty"` // 枚举类型
  68. WeChatId *string `json:"WeChatId,omitempty"` // 微信号
  69. }