add_new_friend_logic.go 1.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475
  1. package contact
  2. import (
  3. "context"
  4. "wechat-api/ent/wx"
  5. "wechat-api/hook"
  6. "wechat-api/internal/svc"
  7. "wechat-api/internal/types"
  8. "github.com/suyuan32/simple-admin-common/msg/errormsg"
  9. "github.com/zeromicro/go-zero/core/logx"
  10. )
  11. type AddNewFriendLogic struct {
  12. logx.Logger
  13. ctx context.Context
  14. svcCtx *svc.ServiceContext
  15. }
  16. func NewAddNewFriendLogic(ctx context.Context, svcCtx *svc.ServiceContext) *AddNewFriendLogic {
  17. return &AddNewFriendLogic{
  18. Logger: logx.WithContext(ctx),
  19. ctx: ctx,
  20. svcCtx: svcCtx}
  21. }
  22. func (l *AddNewFriendLogic) AddNewFriend(req *types.AddNewFriendReq) (resp *types.BaseMsgResp, err error) {
  23. wxInfo, err := l.svcCtx.DB.Wx.Query().Where(wx.Wxid(req.OwnerWxid)).First(l.ctx)
  24. if err != nil {
  25. l.Error("查询微信信息失败", err)
  26. return
  27. }
  28. serverInfo, err := l.svcCtx.DB.Server.Get(l.ctx, wxInfo.ServerID)
  29. if err != nil {
  30. l.Error("查询服务器信息失败", err)
  31. return
  32. }
  33. hookClient := hook.NewHook(serverInfo.PrivateIP, serverInfo.AdminPort, wxInfo.Port)
  34. //通过群id获取群成员详细信息
  35. ChatroomMemberDetailInfo, err := hookClient.GetChatroomMemberDetailInfo(req.Gid, req.Wxid)
  36. if err != nil {
  37. l.Error("获取群成员详细信息失败", err)
  38. return
  39. }
  40. v3 := req.Wxid
  41. v4 := ""
  42. if ChatroomMemberDetailInfo.V3 != "" {
  43. v3 = ChatroomMemberDetailInfo.V3
  44. }
  45. if ChatroomMemberDetailInfo.V4 != "" {
  46. v4 = ChatroomMemberDetailInfo.V4
  47. }
  48. AddNewFriendResult, err := hookClient.AddNewFriend(v3, v4, req.Desc, req.AddType, "0")
  49. if err != nil {
  50. l.Error("添加好友失败", err)
  51. return
  52. }
  53. if AddNewFriendResult.Status != "0" {
  54. l.Error("添加好友失败", err)
  55. return
  56. }
  57. return &types.BaseMsgResp{Msg: errormsg.Success}, nil
  58. }