add_new_friend_logic.go 1.8 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. organizationId := l.ctx.Value("organizationId").(uint64)
  24. wxInfo, err := l.svcCtx.DB.Wx.Query().Where(wx.Wxid(req.OwnerWxid), wx.OrganizationIDEQ(organizationId)).First(l.ctx)
  25. if err != nil {
  26. l.Error("查询微信信息失败", err)
  27. return
  28. }
  29. serverInfo, err := l.svcCtx.DB.Server.Get(l.ctx, wxInfo.ServerID)
  30. if err != nil {
  31. l.Error("查询服务器信息失败", err)
  32. return
  33. }
  34. hookClient := hook.NewHook(serverInfo.PrivateIP, serverInfo.AdminPort, wxInfo.Port)
  35. //通过群id获取群成员详细信息
  36. ChatroomMemberDetailInfo, err := hookClient.GetChatroomMemberDetailInfo(req.Gid, req.Wxid)
  37. if err != nil {
  38. l.Error("获取群成员详细信息失败", err)
  39. return
  40. }
  41. v3 := req.Wxid
  42. v4 := ""
  43. if ChatroomMemberDetailInfo.V3 != "" {
  44. v3 = ChatroomMemberDetailInfo.V3
  45. }
  46. if ChatroomMemberDetailInfo.V4 != "" {
  47. v4 = ChatroomMemberDetailInfo.V4
  48. }
  49. AddNewFriendResult, err := hookClient.AddNewFriend(v3, v4, req.Desc, req.AddType, "0")
  50. if err != nil {
  51. l.Error("添加好友失败", err)
  52. return
  53. }
  54. if AddNewFriendResult.Status != "0" {
  55. l.Error("添加好友失败", err)
  56. return
  57. }
  58. return &types.BaseMsgResp{Msg: errormsg.Success}, nil
  59. }