task_result_notice.go 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. package MessageHandlers
  2. import (
  3. "context"
  4. "encoding/json"
  5. "github.com/zeromicro/go-zero/core/logx"
  6. "time"
  7. "wechat-api/ent/addwechatfriendlog"
  8. "wechat-api/internal/pkg/wechat_ws"
  9. "wechat-api/internal/svc"
  10. "wechat-api/workphone"
  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. message := workphone.TaskResultNoticeMessage{}
  23. err := json.Unmarshal([]byte(msg.Message), &message)
  24. logx.Infof("msg.Message 的内容是:%s", msg.Message)
  25. if err != nil {
  26. logx.Errorf("Unmarshal.fail")
  27. return err
  28. }
  29. if message.TaskType != workphone.EnumMsgType_AddFriendsTask {
  30. logx.Infof("不是添加好友任务的回执")
  31. return nil
  32. }
  33. m, err := ParseJSONStringToMap(msg.Message)
  34. if err != nil {
  35. logx.Errorf("解析 JSON 失败: %v", err)
  36. return err
  37. }
  38. update := svcCtx.DB.AddWechatFriendLog.Update().
  39. Where(addwechatfriendlog.OwnerWxIDEQ(message.WeChatId)).
  40. Where(addwechatfriendlog.TaskIDEQ(message.TaskId)).
  41. //SetFindResult(m).
  42. SetAddResult(m).
  43. SetUpdatedAt(time.Now().Unix())
  44. if message.Success {
  45. update.SetIsCanAdd(2)
  46. }
  47. if _, err := update.Save(ctx); err != nil {
  48. logx.Errorf("更新AddWechatFriendLog-field-add-result失败: %v", err)
  49. return err
  50. }
  51. return nil
  52. }