package group import ( "Open_IM/pkg/common/constant" "Open_IM/pkg/common/db/mysql_model/im_mysql_model" "Open_IM/pkg/common/log" "Open_IM/pkg/common/token_verify" pbGroup "Open_IM/pkg/proto/group" "context" ) func (s *groupServer) GetGroupsInfo(ctx context.Context, req *pbGroup.GetGroupsInfoReq) (*pbGroup.GetGroupsInfoResp, error) { log.Info(req.Token, req.OperationID, "rpc get group info is server,args=%s", req.String()) //Parse token, to find current user information claims, err := token_verify.ParseToken(req.Token) if err != nil { log.Error(req.Token, req.OperationID, "err=%s,parse token failed", err.Error()) return &pbGroup.GetGroupsInfoResp{ErrorCode: constant.ErrParseToken.ErrCode, ErrorMsg: constant.ErrParseToken.ErrMsg}, nil } log.Info("", req.OperationID, "args:", req.GroupIDList, claims.UID) groupsInfoList := make([]*pbGroup.GroupInfo, 0) for _, groupID := range req.GroupIDList { groupInfoFromMysql, err := im_mysql_model.FindGroupInfoByGroupId(groupID) if err != nil { log.Error(req.Token, req.OperationID, "find group info failed,err=%s", err.Error()) continue } var groupInfo pbGroup.GroupInfo groupInfo.GroupId = groupID groupInfo.GroupName = groupInfoFromMysql.Name groupInfo.Introduction = groupInfoFromMysql.Introduction groupInfo.Notification = groupInfoFromMysql.Notification groupInfo.FaceUrl = groupInfoFromMysql.FaceUrl groupInfo.OwnerId = im_mysql_model.GetGroupOwnerByGroupId(groupID) groupInfo.MemberCount = uint32(im_mysql_model.GetGroupMemberNumByGroupId(groupID)) groupInfo.CreateTime = uint64(groupInfoFromMysql.CreateTime.Unix()) groupsInfoList = append(groupsInfoList, &groupInfo) } log.Info(req.Token, req.OperationID, "rpc get groupsInfo success return") return &pbGroup.GetGroupsInfoResp{Data: groupsInfoList}, nil }