package friend import ( "Open_IM/pkg/common/config" "Open_IM/pkg/common/db/mysql_model/im_mysql_model" "Open_IM/pkg/common/log" pbFriend "Open_IM/pkg/proto/friend" "Open_IM/pkg/utils" "context" "fmt" "strconv" ) func (s *friendServer) GetFriendApplyList(ctx context.Context, req *pbFriend.GetFriendApplyReq) (*pbFriend.GetFriendApplyResp, error) { log.Info(req.Token, req.OperationID, "rpc get friend apply list is server,args=%s", req.String()) var appleUserList []*pbFriend.ApplyUserInfo //Parse token, to find current user information claims, err := utils.ParseToken(req.Token) if err != nil { log.Error(req.Token, req.OperationID, "err=%s,parse token failed", err.Error()) return &pbFriend.GetFriendApplyResp{ErrorCode: config.ErrParseToken.ErrCode, ErrorMsg: config.ErrParseToken.ErrMsg}, nil } // Find the current user friend applications received ApplyUsersInfo, err := im_mysql_model.FindFriendsApplyFromFriendReq(claims.UID) if err != nil { log.Error(req.Token, req.OperationID, "err=%s,search applyInfo failed", err.Error()) return &pbFriend.GetFriendApplyResp{ErrorCode: config.ErrMysql.ErrCode, ErrorMsg: config.ErrMysql.ErrMsg}, nil } for _, applyUserInfo := range ApplyUsersInfo { var userInfo pbFriend.ApplyUserInfo //Find friend application status userInfo.Flag = applyUserInfo.Flag userInfo.ReqMessage = applyUserInfo.ReqMessage userInfo.ApplyTime = strconv.FormatInt(applyUserInfo.CreateTime.Unix(), 10) //Find user information us, err := im_mysql_model.FindUserByUID(applyUserInfo.ReqId) if err != nil { log.Error(req.Token, req.OperationID, "err=%s,search userInfo failed", err.Error()) continue } userInfo.Uid = us.UID userInfo.Icon = us.Icon userInfo.Name = us.Name userInfo.Gender = us.Gender userInfo.Mobile = us.Mobile userInfo.Birth = us.Birth userInfo.Email = us.Email userInfo.Ex = us.Ex appleUserList = append(appleUserList, &userInfo) } log.Info(req.Token, req.OperationID, fmt.Sprintf("rpc get friendapplylist success return")) return &pbFriend.GetFriendApplyResp{Data: appleUserList}, nil } func (s *friendServer) GetSelfApplyList(ctx context.Context, req *pbFriend.GetFriendApplyReq) (*pbFriend.GetFriendApplyResp, error) { log.Info(req.Token, req.OperationID, "rpc get self apply list is server,args=%s", req.String()) var selfApplyOtherUserList []*pbFriend.ApplyUserInfo //Parse token, to find current user information claims, err := utils.ParseToken(req.Token) if err != nil { log.Error(req.Token, req.OperationID, "err=%s,parse token failed", err.Error()) return &pbFriend.GetFriendApplyResp{ErrorCode: config.ErrParseToken.ErrCode, ErrorMsg: config.ErrParseToken.ErrMsg}, nil } // Find the self add other userinfo usersInfo, err := im_mysql_model.FindSelfApplyFromFriendReq(claims.UID) if err != nil { log.Error(req.Token, req.OperationID, "err=%s,search self to other user Info failed", err.Error()) return &pbFriend.GetFriendApplyResp{ErrorCode: config.ErrMysql.ErrCode, ErrorMsg: config.ErrMysql.ErrMsg}, nil } for _, selfApplyOtherUserInfo := range usersInfo { var userInfo pbFriend.ApplyUserInfo //Find friend application status userInfo.Flag = selfApplyOtherUserInfo.Flag userInfo.ReqMessage = selfApplyOtherUserInfo.ReqMessage userInfo.ApplyTime = strconv.FormatInt(selfApplyOtherUserInfo.CreateTime.Unix(), 10) //Find user information us, err := im_mysql_model.FindUserByUID(selfApplyOtherUserInfo.Uid) if err != nil { log.Error(req.Token, req.OperationID, "err=%s,search userInfo failed", err.Error()) continue } userInfo.Uid = us.UID userInfo.Icon = us.Icon userInfo.Name = us.Name userInfo.Gender = us.Gender userInfo.Mobile = us.Mobile userInfo.Birth = us.Birth userInfo.Email = us.Email userInfo.Ex = us.Ex selfApplyOtherUserList = append(selfApplyOtherUserList, &userInfo) } log.Info(req.Token, req.OperationID, fmt.Sprintf("rpc get self apply list success return")) return &pbFriend.GetFriendApplyResp{Data: selfApplyOtherUserList}, nil }