Files
open-im-server/internal/rpc/friend/firend.go
T

520 lines
25 KiB
Go
Raw Normal View History

2021-12-23 17:22:49 +08:00
package friend
import (
2021-12-24 15:02:47 +08:00
chat "Open_IM/internal/rpc/msg"
2021-12-23 17:22:49 +08:00
"Open_IM/pkg/common/config"
"Open_IM/pkg/common/constant"
2021-12-31 10:57:45 +08:00
"Open_IM/pkg/common/db"
2021-12-23 17:22:49 +08:00
imdb "Open_IM/pkg/common/db/mysql_model/im_mysql_model"
"Open_IM/pkg/common/log"
"Open_IM/pkg/common/token_verify"
2021-12-28 15:33:47 +08:00
cp "Open_IM/pkg/common/utils"
2021-12-23 17:22:49 +08:00
"Open_IM/pkg/grpc-etcdv3/getcdv3"
pbFriend "Open_IM/pkg/proto/friend"
2021-12-26 18:47:11 +08:00
sdkws "Open_IM/pkg/proto/sdk_ws"
2021-12-23 17:22:49 +08:00
"Open_IM/pkg/utils"
"context"
"google.golang.org/grpc"
"net"
"strconv"
"strings"
2021-12-28 15:33:47 +08:00
"time"
2021-12-23 17:22:49 +08:00
)
type friendServer struct {
rpcPort int
rpcRegisterName string
etcdSchema string
etcdAddr []string
}
func NewFriendServer(port int) *friendServer {
2022-03-31 11:15:06 +08:00
log.NewPrivateLog(constant.LogFileName)
2021-12-23 17:22:49 +08:00
return &friendServer{
rpcPort: port,
rpcRegisterName: config.Config.RpcRegisterName.OpenImFriendName,
etcdSchema: config.Config.Etcd.EtcdSchema,
etcdAddr: config.Config.Etcd.EtcdAddr,
}
}
func (s *friendServer) Run() {
2021-12-26 18:47:11 +08:00
log.NewInfo("0", "friendServer run...")
2021-12-23 17:22:49 +08:00
ip := utils.ServerIP
registerAddress := ip + ":" + strconv.Itoa(s.rpcPort)
//listener network
listener, err := net.Listen("tcp", registerAddress)
if err != nil {
2021-12-26 18:47:11 +08:00
log.NewError("0", "Listen failed ", err.Error(), registerAddress)
2021-12-23 17:22:49 +08:00
return
}
2021-12-26 18:47:11 +08:00
log.NewInfo("0", "listen ok ", registerAddress)
2021-12-23 17:22:49 +08:00
defer listener.Close()
//grpc server
srv := grpc.NewServer()
defer srv.GracefulStop()
//User friend related services register to etcd
pbFriend.RegisterFriendServer(srv, s)
err = getcdv3.RegisterEtcd(s.etcdSchema, strings.Join(s.etcdAddr, ","), ip, s.rpcPort, s.rpcRegisterName, 10)
if err != nil {
2021-12-26 18:47:11 +08:00
log.NewError("0", "RegisterEtcd failed ", err.Error(), s.etcdSchema, strings.Join(s.etcdAddr, ","), ip, s.rpcPort, s.rpcRegisterName)
2021-12-23 17:22:49 +08:00
return
}
err = srv.Serve(listener)
if err != nil {
2021-12-26 18:47:11 +08:00
log.NewError("0", "Serve failed ", err.Error(), listener)
2021-12-23 17:22:49 +08:00
return
}
}
2021-12-26 18:47:11 +08:00
func (s *friendServer) AddBlacklist(ctx context.Context, req *pbFriend.AddBlacklistReq) (*pbFriend.AddBlacklistResp, error) {
2021-12-23 17:22:49 +08:00
log.NewInfo(req.CommID.OperationID, "AddBlacklist args ", req.String())
ok := token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID)
if !ok {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
return &pbFriend.AddBlacklistResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-31 10:57:45 +08:00
black := db.Black{OwnerUserID: req.CommID.FromUserID, BlockUserID: req.CommID.ToUserID, OperatorUserID: req.CommID.OpUserID}
2021-12-23 17:22:49 +08:00
2021-12-27 21:08:42 +08:00
err := imdb.InsertInToUserBlackList(black)
2021-12-23 17:22:49 +08:00
if err != nil {
log.NewError(req.CommID.OperationID, "InsertInToUserBlackList failed ", err.Error())
2021-12-26 18:47:11 +08:00
return &pbFriend.AddBlacklistResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-28 11:57:12 +08:00
log.NewInfo(req.CommID.OperationID, "AddBlacklist rpc ok ", req.CommID.FromUserID, req.CommID.ToUserID)
2021-12-24 15:02:47 +08:00
chat.BlackAddedNotification(req)
2021-12-26 18:47:11 +08:00
return &pbFriend.AddBlacklistResp{CommonResp: &pbFriend.CommonResp{}}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-26 18:47:11 +08:00
func (s *friendServer) AddFriend(ctx context.Context, req *pbFriend.AddFriendReq) (*pbFriend.AddFriendResp, error) {
2021-12-23 17:22:49 +08:00
log.NewInfo(req.CommID.OperationID, "AddFriend args ", req.String())
ok := token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID)
if !ok {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
return &pbFriend.AddFriendResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
//Cannot add non-existent users
2021-12-27 21:08:42 +08:00
if _, err := imdb.GetUserByUserID(req.CommID.ToUserID); err != nil {
log.NewError(req.CommID.OperationID, "GetUserByUserID failed ", err.Error(), req.CommID.ToUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.AddFriendResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
//Establish a latest relationship in the friend request table
2022-02-15 14:34:03 +08:00
friendRequest := db.FriendRequest{
HandleResult: 0, ReqMsg: req.ReqMsg, CreateTime: time.Now()}
2021-12-27 21:08:42 +08:00
utils.CopyStructFields(&friendRequest, req.CommID)
2021-12-29 10:52:52 +08:00
// {openIM001 openIM002 0 test add friend 0001-01-01 00:00:00 +0000 UTC 0001-01-01 00:00:00 +0000 UTC }]
2021-12-29 10:39:47 +08:00
log.NewDebug(req.CommID.OperationID, "UpdateFriendApplication args ", friendRequest)
2022-02-08 20:22:07 +08:00
//err := imdb.InsertFriendApplication(&friendRequest)
2022-02-14 16:59:52 +08:00
err := imdb.InsertFriendApplication(&friendRequest,
2022-02-15 14:34:03 +08:00
map[string]interface{}{"handle_result": 0, "req_msg": friendRequest.ReqMsg, "create_time": friendRequest.CreateTime,
"handler_user_id": "", "handle_msg": "", "handle_time": utils.UnixSecondToTime(0), "ex": ""})
2021-12-23 17:22:49 +08:00
if err != nil {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "UpdateFriendApplication failed ", err.Error(), friendRequest)
2021-12-26 18:47:11 +08:00
return &pbFriend.AddFriendResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
2022-01-16 16:31:28 +08:00
chat.FriendApplicationNotification(req)
2021-12-26 18:47:11 +08:00
return &pbFriend.AddFriendResp{CommonResp: &pbFriend.CommonResp{}}, nil
2021-12-23 17:22:49 +08:00
}
func (s *friendServer) ImportFriend(ctx context.Context, req *pbFriend.ImportFriendReq) (*pbFriend.ImportFriendResp, error) {
2021-12-29 16:44:24 +08:00
log.NewInfo(req.OperationID, "ImportFriend args ", req.String())
2021-12-29 16:39:52 +08:00
resp := pbFriend.ImportFriendResp{CommonResp: &pbFriend.CommonResp{}}
2021-12-23 17:22:49 +08:00
var c pbFriend.CommonResp
if !utils.IsContain(req.OpUserID, config.Config.Manager.AppManagerUid) {
2021-12-28 11:57:12 +08:00
log.NewError(req.OperationID, "not authorized", req.OpUserID, config.Config.Manager.AppManagerUid)
2021-12-26 18:47:11 +08:00
c.ErrCode = constant.ErrAccess.ErrCode
c.ErrMsg = constant.ErrAccess.ErrMsg
2021-12-29 16:17:55 +08:00
for _, v := range req.FriendUserIDList {
resp.UserIDResultList = append(resp.UserIDResultList, &pbFriend.UserIDResult{UserID: v, Result: -1})
}
resp.CommonResp = &c
return &resp, nil
2021-12-23 17:22:49 +08:00
}
2021-12-27 21:08:42 +08:00
if _, err := imdb.GetUserByUserID(req.FromUserID); err != nil {
2021-12-28 11:57:12 +08:00
log.NewError(req.OperationID, "GetUserByUserID failed ", err.Error(), req.FromUserID)
2021-12-26 18:47:11 +08:00
c.ErrCode = constant.ErrDB.ErrCode
2021-12-23 17:22:49 +08:00
c.ErrMsg = "this user not exists,cant not add friend"
2021-12-29 16:17:55 +08:00
for _, v := range req.FriendUserIDList {
resp.UserIDResultList = append(resp.UserIDResultList, &pbFriend.UserIDResult{UserID: v, Result: -1})
}
resp.CommonResp = &c
return &resp, nil
2021-12-23 17:22:49 +08:00
}
for _, v := range req.FriendUserIDList {
2021-12-29 17:06:40 +08:00
log.NewDebug(req.OperationID, "FriendUserIDList ", v)
2021-12-27 21:08:42 +08:00
if _, fErr := imdb.GetUserByUserID(v); fErr != nil {
2021-12-29 17:13:45 +08:00
log.NewError(req.OperationID, "GetUserByUserID failed ", fErr.Error(), v)
2021-12-29 16:17:55 +08:00
resp.UserIDResultList = append(resp.UserIDResultList, &pbFriend.UserIDResult{UserID: v, Result: -1})
2021-12-23 17:22:49 +08:00
} else {
2021-12-27 21:08:42 +08:00
if _, err := imdb.GetFriendRelationshipFromFriend(req.FromUserID, v); err != nil {
2021-12-23 17:22:49 +08:00
//Establish two single friendship
2021-12-31 10:57:45 +08:00
toInsertFollow := db.Friend{OwnerUserID: req.FromUserID, FriendUserID: v}
2021-12-27 21:08:42 +08:00
err1 := imdb.InsertToFriend(&toInsertFollow)
2021-12-23 17:22:49 +08:00
if err1 != nil {
2021-12-29 17:13:45 +08:00
log.NewError(req.OperationID, "InsertToFriend failed ", err1.Error(), toInsertFollow)
2021-12-29 16:17:55 +08:00
resp.UserIDResultList = append(resp.UserIDResultList, &pbFriend.UserIDResult{UserID: v, Result: -1})
2021-12-23 17:22:49 +08:00
continue
}
2021-12-31 10:57:45 +08:00
toInsertFollow = db.Friend{OwnerUserID: v, FriendUserID: req.FromUserID}
2021-12-27 21:08:42 +08:00
err2 := imdb.InsertToFriend(&toInsertFollow)
2021-12-23 17:22:49 +08:00
if err2 != nil {
2021-12-29 17:13:45 +08:00
log.NewError(req.OperationID, "InsertToFriend failed ", err2.Error(), toInsertFollow)
2021-12-29 16:17:55 +08:00
resp.UserIDResultList = append(resp.UserIDResultList, &pbFriend.UserIDResult{UserID: v, Result: -1})
2021-12-23 17:22:49 +08:00
continue
}
2021-12-29 16:52:12 +08:00
resp.UserIDResultList = append(resp.UserIDResultList, &pbFriend.UserIDResult{UserID: v, Result: 0})
2021-12-29 16:55:45 +08:00
log.NewDebug(req.OperationID, "UserIDResultList ", resp.UserIDResultList)
2021-12-29 16:52:12 +08:00
chat.FriendAddedNotification(req.OperationID, req.OpUserID, req.FromUserID, v)
2021-12-29 17:13:45 +08:00
} else {
log.NewWarn(req.OperationID, "GetFriendRelationshipFromFriend ok", req.FromUserID, v)
resp.UserIDResultList = append(resp.UserIDResultList, &pbFriend.UserIDResult{UserID: v, Result: 0})
2021-12-23 17:22:49 +08:00
}
}
}
2021-12-29 16:17:55 +08:00
resp.CommonResp.ErrCode = 0
log.NewInfo(req.OperationID, "ImportFriend rpc ok ", resp.String())
2021-12-23 17:22:49 +08:00
return &resp, nil
}
2021-12-24 15:02:47 +08:00
//process Friend application
2021-12-26 18:47:11 +08:00
func (s *friendServer) AddFriendResponse(ctx context.Context, req *pbFriend.AddFriendResponseReq) (*pbFriend.AddFriendResponseResp, error) {
2021-12-23 17:22:49 +08:00
log.NewInfo(req.CommID.OperationID, "AddFriendResponse args ", req.String())
2021-12-28 11:57:12 +08:00
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.AddFriendResponseResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
//Check there application before agreeing or refuse to a friend's application
//req.CommID.FromUserID process req.CommID.ToUserID
2021-12-27 21:08:42 +08:00
friendRequest, err := imdb.GetFriendApplicationByBothUserID(req.CommID.ToUserID, req.CommID.FromUserID)
if err != nil {
log.NewError(req.CommID.OperationID, "GetFriendApplicationByBothUserID failed ", err.Error(), req.CommID.ToUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.AddFriendResponseResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
2022-01-16 16:31:28 +08:00
friendRequest.HandleResult = req.HandleResult
2021-12-28 11:57:12 +08:00
friendRequest.HandleTime = time.Now()
2021-12-28 15:33:47 +08:00
//friendRequest.HandleTime.Unix()
2021-12-28 11:57:12 +08:00
friendRequest.HandleMsg = req.HandleMsg
friendRequest.HandlerUserID = req.CommID.OpUserID
2021-12-27 21:08:42 +08:00
err = imdb.UpdateFriendApplication(friendRequest)
2021-12-23 17:22:49 +08:00
if err != nil {
2021-12-27 21:08:42 +08:00
log.NewError(req.CommID.OperationID, "UpdateFriendApplication failed ", err.Error(), friendRequest)
2021-12-26 18:47:11 +08:00
return &pbFriend.AddFriendResponseResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-27 21:08:42 +08:00
2021-12-23 17:22:49 +08:00
//Change the status of the friend request form
2022-01-16 16:31:28 +08:00
if req.HandleResult == constant.FriendFlag {
2021-12-23 17:22:49 +08:00
//Establish friendship after find friend relationship not exists
2021-12-28 11:57:12 +08:00
_, err := imdb.GetFriendRelationshipFromFriend(req.CommID.FromUserID, req.CommID.ToUserID)
2021-12-23 17:22:49 +08:00
if err == nil {
2021-12-28 11:57:12 +08:00
log.NewWarn(req.CommID.OperationID, "GetFriendRelationshipFromFriend exist", req.CommID.FromUserID, req.CommID.ToUserID)
2021-12-23 17:22:49 +08:00
} else {
//Establish two single friendship
2021-12-31 10:57:45 +08:00
toInsertFollow := db.Friend{OwnerUserID: req.CommID.FromUserID, FriendUserID: req.CommID.ToUserID, OperatorUserID: req.CommID.OpUserID}
2021-12-28 11:57:12 +08:00
err = imdb.InsertToFriend(&toInsertFollow)
2021-12-23 17:22:49 +08:00
if err != nil {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "InsertToFriend failed ", err.Error(), toInsertFollow)
2021-12-26 18:47:11 +08:00
return &pbFriend.AddFriendResponseResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
}
2021-12-28 11:57:12 +08:00
_, err = imdb.GetFriendRelationshipFromFriend(req.CommID.ToUserID, req.CommID.FromUserID)
2021-12-23 17:22:49 +08:00
if err == nil {
2021-12-29 12:29:39 +08:00
log.NewWarn(req.CommID.OperationID, "GetFriendRelationshipFromFriend exist", req.CommID.ToUserID, req.CommID.FromUserID)
2021-12-29 12:13:00 +08:00
} else {
2021-12-31 10:57:45 +08:00
toInsertFollow := db.Friend{OwnerUserID: req.CommID.ToUserID, FriendUserID: req.CommID.FromUserID, OperatorUserID: req.CommID.OpUserID}
2021-12-29 12:13:00 +08:00
err = imdb.InsertToFriend(&toInsertFollow)
if err != nil {
log.NewError(req.CommID.OperationID, "InsertToFriend failed ", err.Error(), toInsertFollow)
return &pbFriend.AddFriendResponseResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}}, nil
}
chat.FriendAddedNotification(req.CommID.OperationID, req.CommID.OpUserID, req.CommID.FromUserID, req.CommID.ToUserID)
2021-12-23 17:22:49 +08:00
}
}
2022-01-16 16:31:28 +08:00
if req.HandleResult == constant.FriendResponseAgree {
chat.FriendApplicationApprovedNotification(req)
} else if req.HandleResult == constant.FriendResponseRefuse {
chat.FriendApplicationRejectedNotification(req)
} else {
log.Error(req.CommID.OperationID, "HandleResult failed ", req.HandleResult)
}
2021-12-28 11:57:12 +08:00
log.NewInfo(req.CommID.OperationID, "rpc AddFriendResponse ok")
2021-12-26 18:47:11 +08:00
return &pbFriend.AddFriendResponseResp{CommonResp: &pbFriend.CommonResp{}}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-26 18:47:11 +08:00
func (s *friendServer) DeleteFriend(ctx context.Context, req *pbFriend.DeleteFriendReq) (*pbFriend.DeleteFriendResp, error) {
2021-12-23 17:22:49 +08:00
log.NewInfo(req.CommID.OperationID, "DeleteFriend args ", req.String())
//Parse token, to find current user information
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.DeleteFriendResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
err := imdb.DeleteSingleFriendInfo(req.CommID.FromUserID, req.CommID.ToUserID)
if err != nil {
log.NewError(req.CommID.OperationID, "DeleteSingleFriendInfo failed", err.Error(), req.CommID.FromUserID, req.CommID.ToUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.DeleteFriendResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
log.NewInfo(req.CommID.OperationID, "DeleteFriend rpc ok")
2021-12-24 15:02:47 +08:00
chat.FriendDeletedNotification(req)
2021-12-26 18:47:11 +08:00
return &pbFriend.DeleteFriendResp{CommonResp: &pbFriend.CommonResp{}}, nil
2021-12-23 17:22:49 +08:00
}
func (s *friendServer) GetBlacklist(ctx context.Context, req *pbFriend.GetBlacklistReq) (*pbFriend.GetBlacklistResp, error) {
log.NewInfo(req.CommID.OperationID, "GetBlacklist args ", req.String())
//Parse token, to find current user information
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.GetBlacklistResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-27 21:08:42 +08:00
blackListInfo, err := imdb.GetBlackListByUserID(req.CommID.FromUserID)
2021-12-23 17:22:49 +08:00
if err != nil {
log.NewError(req.CommID.OperationID, "GetBlackListByUID failed ", err.Error(), req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.GetBlacklistResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
var (
2021-12-26 18:47:11 +08:00
userInfoList []*sdkws.PublicUserInfo
2021-12-23 17:22:49 +08:00
)
for _, blackUser := range blackListInfo {
2021-12-26 18:47:11 +08:00
var blackUserInfo sdkws.PublicUserInfo
2021-12-23 17:22:49 +08:00
//Find black user information
2021-12-27 21:08:42 +08:00
us, err := imdb.GetUserByUserID(blackUser.BlockUserID)
2021-12-23 17:22:49 +08:00
if err != nil {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "GetUserByUserID failed ", err.Error(), blackUser.BlockUserID)
2021-12-23 17:22:49 +08:00
continue
}
utils.CopyStructFields(&blackUserInfo, us)
userInfoList = append(userInfoList, &blackUserInfo)
}
2021-12-28 11:57:12 +08:00
log.NewInfo(req.CommID.OperationID, "rpc GetBlacklist ok ", pbFriend.GetBlacklistResp{BlackUserInfoList: userInfoList})
2021-12-26 18:47:11 +08:00
return &pbFriend.GetBlacklistResp{BlackUserInfoList: userInfoList}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-29 14:25:39 +08:00
func (s *friendServer) SetFriendRemark(ctx context.Context, req *pbFriend.SetFriendRemarkReq) (*pbFriend.SetFriendRemarkResp, error) {
2021-12-23 17:22:49 +08:00
log.NewInfo(req.CommID.OperationID, "SetFriendComment args ", req.String())
//Parse token, to find current user information
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-29 14:25:39 +08:00
return &pbFriend.SetFriendRemarkResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-28 11:57:12 +08:00
err := imdb.UpdateFriendComment(req.CommID.FromUserID, req.CommID.ToUserID, req.Remark)
2021-12-23 17:22:49 +08:00
if err != nil {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "UpdateFriendComment failed ", req.CommID.FromUserID, req.CommID.ToUserID, req.Remark)
2021-12-29 14:25:39 +08:00
return &pbFriend.SetFriendRemarkResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
log.NewInfo(req.CommID.OperationID, "rpc SetFriendComment ok")
2022-01-16 16:31:28 +08:00
chat.FriendRemarkSetNotification(req.CommID.OperationID, req.CommID.OpUserID, req.CommID.FromUserID, req.CommID.ToUserID)
2021-12-29 14:25:39 +08:00
return &pbFriend.SetFriendRemarkResp{CommonResp: &pbFriend.CommonResp{}}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-26 18:47:11 +08:00
func (s *friendServer) RemoveBlacklist(ctx context.Context, req *pbFriend.RemoveBlacklistReq) (*pbFriend.RemoveBlacklistResp, error) {
2021-12-23 17:22:49 +08:00
log.NewInfo(req.CommID.OperationID, "RemoveBlacklist args ", req.String())
//Parse token, to find current user information
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.RemoveBlacklistResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
err := imdb.RemoveBlackList(req.CommID.FromUserID, req.CommID.ToUserID)
if err != nil {
log.NewError(req.CommID.OperationID, "RemoveBlackList failed", err.Error(), req.CommID.FromUserID, req.CommID.ToUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.RemoveBlacklistResp{CommonResp: &pbFriend.CommonResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-28 11:57:12 +08:00
log.NewInfo(req.CommID.OperationID, "rpc RemoveBlacklist ok ")
2021-12-24 15:02:47 +08:00
chat.BlackDeletedNotification(req)
2021-12-26 18:47:11 +08:00
return &pbFriend.RemoveBlacklistResp{CommonResp: &pbFriend.CommonResp{}}, nil
2021-12-23 17:22:49 +08:00
}
func (s *friendServer) IsInBlackList(ctx context.Context, req *pbFriend.IsInBlackListReq) (*pbFriend.IsInBlackListResp, error) {
log.NewInfo("IsInBlackList args ", req.String())
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.IsInBlackListResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
var isInBlacklist = false
2021-12-27 21:08:42 +08:00
err := imdb.CheckBlack(req.CommID.FromUserID, req.CommID.ToUserID)
2021-12-23 17:22:49 +08:00
if err == nil {
isInBlacklist = true
}
2021-12-28 11:57:12 +08:00
log.NewInfo(req.CommID.OperationID, "IsInBlackList rpc ok ", pbFriend.IsInBlackListResp{Response: isInBlacklist})
2021-12-23 17:22:49 +08:00
return &pbFriend.IsInBlackListResp{Response: isInBlacklist}, nil
}
func (s *friendServer) IsFriend(ctx context.Context, req *pbFriend.IsFriendReq) (*pbFriend.IsFriendResp, error) {
2022-03-18 18:18:10 +08:00
log.NewInfo(req.CommID.OperationID, req.String())
2021-12-26 18:47:11 +08:00
var isFriend bool
2021-12-23 17:22:49 +08:00
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.IsFriendResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-27 21:08:42 +08:00
_, err := imdb.GetFriendRelationshipFromFriend(req.CommID.FromUserID, req.CommID.ToUserID)
2021-12-23 17:22:49 +08:00
if err == nil {
2021-12-26 18:47:11 +08:00
isFriend = true
2021-12-23 17:22:49 +08:00
} else {
2021-12-26 18:47:11 +08:00
isFriend = false
2021-12-23 17:22:49 +08:00
}
2022-03-18 18:18:10 +08:00
log.NewInfo(req.CommID.OperationID, pbFriend.IsFriendResp{Response: isFriend})
2021-12-26 18:47:11 +08:00
return &pbFriend.IsFriendResp{Response: isFriend}, nil
2021-12-23 17:22:49 +08:00
}
func (s *friendServer) GetFriendList(ctx context.Context, req *pbFriend.GetFriendListReq) (*pbFriend.GetFriendListResp, error) {
log.NewInfo("GetFriendList args ", req.String())
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.GetFriendListResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-28 11:57:12 +08:00
friends, err := imdb.GetFriendListByUserID(req.CommID.FromUserID)
2021-12-23 17:22:49 +08:00
if err != nil {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "FindUserInfoFromFriend failed ", err.Error(), req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.GetFriendListResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-28 11:57:12 +08:00
var userInfoList []*sdkws.FriendInfo
2021-12-23 17:22:49 +08:00
for _, friendUser := range friends {
2021-12-29 14:14:08 +08:00
friendUserInfo := sdkws.FriendInfo{FriendUser: &sdkws.UserInfo{}}
2021-12-29 14:06:25 +08:00
cp.FriendDBCopyOpenIM(&friendUserInfo, &friendUser)
log.NewDebug(req.CommID.OperationID, "friends : ", friendUser, "openim friends: ", friendUserInfo)
2021-12-23 17:22:49 +08:00
userInfoList = append(userInfoList, &friendUserInfo)
}
2021-12-26 18:47:11 +08:00
log.NewInfo(req.CommID.OperationID, "rpc GetFriendList ok", pbFriend.GetFriendListResp{FriendInfoList: userInfoList})
return &pbFriend.GetFriendListResp{FriendInfoList: userInfoList}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-28 11:57:12 +08:00
//received
2021-12-26 18:47:11 +08:00
func (s *friendServer) GetFriendApplyList(ctx context.Context, req *pbFriend.GetFriendApplyListReq) (*pbFriend.GetFriendApplyListResp, error) {
2021-12-23 17:22:49 +08:00
log.NewInfo(req.CommID.OperationID, "GetFriendApplyList args ", req.String())
//Parse token, to find current user information
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.GetFriendApplyListResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
// Find the current user friend applications received
2021-12-27 21:08:42 +08:00
ApplyUsersInfo, err := imdb.GetReceivedFriendsApplicationListByUserID(req.CommID.FromUserID)
2021-12-23 17:22:49 +08:00
if err != nil {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "GetReceivedFriendsApplicationListByUserID ", err.Error(), req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.GetFriendApplyListResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-26 18:47:11 +08:00
var appleUserList []*sdkws.FriendRequest
2021-12-23 17:22:49 +08:00
for _, applyUserInfo := range ApplyUsersInfo {
2021-12-26 18:47:11 +08:00
var userInfo sdkws.FriendRequest
2022-02-11 19:58:42 +08:00
cp.FriendRequestDBCopyOpenIM(&userInfo, &applyUserInfo)
// utils.CopyStructFields(&userInfo, applyUserInfo)
// u, err := imdb.GetUserByUserID(userInfo.FromUserID)
// if err != nil {
// log.Error(req.CommID.OperationID, "GetUserByUserID", userInfo.FromUserID)
// continue
// }
// userInfo.FromNickname = u.Nickname
// userInfo.FromFaceURL = u.FaceURL
// userInfo.FromGender = u.Gender
//
// u, err = imdb.GetUserByUserID(userInfo.ToUserID)
// if err != nil {
// log.Error(req.CommID.OperationID, "GetUserByUserID", userInfo.ToUserID)
// continue
// }
// userInfo.ToNickname = u.Nickname
// userInfo.ToFaceURL = u.FaceURL
// userInfo.ToGender = u.Gender
2021-12-23 17:22:49 +08:00
appleUserList = append(appleUserList, &userInfo)
}
2022-01-14 18:29:09 +08:00
2021-12-26 18:47:11 +08:00
log.NewInfo(req.CommID.OperationID, "rpc GetFriendApplyList ok", pbFriend.GetFriendApplyListResp{FriendRequestList: appleUserList})
return &pbFriend.GetFriendApplyListResp{FriendRequestList: appleUserList}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-26 18:47:11 +08:00
func (s *friendServer) GetSelfApplyList(ctx context.Context, req *pbFriend.GetSelfApplyListReq) (*pbFriend.GetSelfApplyListResp, error) {
2021-12-23 17:22:49 +08:00
log.NewInfo(req.CommID.OperationID, "GetSelfApplyList args ", req.String())
2021-12-28 11:57:12 +08:00
2021-12-23 17:22:49 +08:00
//Parse token, to find current user information
if !token_verify.CheckAccess(req.CommID.OpUserID, req.CommID.FromUserID) {
log.NewError(req.CommID.OperationID, "CheckAccess false ", req.CommID.OpUserID, req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.GetSelfApplyListResp{ErrCode: constant.ErrAccess.ErrCode, ErrMsg: constant.ErrAccess.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
// Find the self add other userinfo
2021-12-27 21:08:42 +08:00
usersInfo, err := imdb.GetSendFriendApplicationListByUserID(req.CommID.FromUserID)
2021-12-23 17:22:49 +08:00
if err != nil {
2021-12-28 11:57:12 +08:00
log.NewError(req.CommID.OperationID, "GetSendFriendApplicationListByUserID failed ", err.Error(), req.CommID.FromUserID)
2021-12-26 18:47:11 +08:00
return &pbFriend.GetSelfApplyListResp{ErrCode: constant.ErrDB.ErrCode, ErrMsg: constant.ErrDB.ErrMsg}, nil
2021-12-23 17:22:49 +08:00
}
2021-12-28 11:57:12 +08:00
var selfApplyOtherUserList []*sdkws.FriendRequest
2021-12-23 17:22:49 +08:00
for _, selfApplyOtherUserInfo := range usersInfo {
2021-12-26 18:47:11 +08:00
var userInfo sdkws.FriendRequest // pbFriend.ApplyUserInfo
2021-12-29 14:08:46 +08:00
cp.FriendRequestDBCopyOpenIM(&userInfo, &selfApplyOtherUserInfo)
2022-02-11 20:31:57 +08:00
//u, err := imdb.GetUserByUserID(userInfo.FromUserID)
//if err != nil {
// log.Error(req.CommID.OperationID, "GetUserByUserID", userInfo.FromUserID)
// continue
//}
//userInfo.FromNickname = u.Nickname
//userInfo.FromFaceURL = u.FaceURL
//userInfo.FromGender = u.Gender
//
//u, err = imdb.GetUserByUserID(userInfo.ToUserID)
//if err != nil {
// log.Error(req.CommID.OperationID, "GetUserByUserID", userInfo.ToUserID)
// continue
//}
//userInfo.ToNickname = u.Nickname
//userInfo.ToFaceURL = u.FaceURL
//userInfo.ToGender = u.Gender
2022-01-14 18:33:06 +08:00
2021-12-23 17:22:49 +08:00
selfApplyOtherUserList = append(selfApplyOtherUserList, &userInfo)
}
2021-12-26 18:47:11 +08:00
log.NewInfo(req.CommID.OperationID, "rpc GetSelfApplyList ok", pbFriend.GetSelfApplyListResp{FriendRequestList: selfApplyOtherUserList})
return &pbFriend.GetSelfApplyListResp{FriendRequestList: selfApplyOtherUserList}, nil
2021-12-23 17:22:49 +08:00
}
2022-01-16 16:31:28 +08:00
////
//func (s *friendServer) GetFriendsInfo(ctx context.Context, req *pbFriend.GetFriendsInfoReq) (*pbFriend.GetFriendInfoResp, error) {
// return nil, nil
//// log.NewInfo(req.CommID.OperationID, "GetFriendsInfo args ", req.String())
//// var (
//// isInBlackList int32
//// // isFriend int32
//// comment string
//// )
////
//// friendShip, err := imdb.FindFriendRelationshipFromFriend(req.CommID.FromUserID, req.CommID.ToUserID)
//// if err != nil {
//// log.NewError(req.CommID.OperationID, "FindFriendRelationshipFromFriend failed ", err.Error())
//// return &pbFriend.GetFriendInfoResp{ErrCode: constant.ErrSearchUserInfo.ErrCode, ErrMsg: constant.ErrSearchUserInfo.ErrMsg}, nil
//// // isFriend = constant.FriendFlag
//// }
//// comment = friendShip.Remark
////
//// friendUserInfo, err := imdb.FindUserByUID(req.CommID.ToUserID)
//// if err != nil {
//// log.NewError(req.CommID.OperationID, "FindUserByUID failed ", err.Error())
//// return &pbFriend.GetFriendInfoResp{ErrCode: constant.ErrSearchUserInfo.ErrCode, ErrMsg: constant.ErrSearchUserInfo.ErrMsg}, nil
//// }
////
//// err = imdb.FindRelationshipFromBlackList(req.CommID.FromUserID, req.CommID.ToUserID)
//// if err == nil {
//// isInBlackList = constant.BlackListFlag
//// }
////
//// resp := pbFriend.GetFriendInfoResp{ErrCode: 0, ErrMsg: "",}
////
//// utils.CopyStructFields(resp.FriendInfoList, friendUserInfo)
//// resp.Data.IsBlack = isInBlackList
//// resp.Data.OwnerUserID = req.CommID.FromUserID
//// resp.Data.Remark = comment
//// resp.Data.CreateTime = friendUserInfo.CreateTime
////
//// log.NewInfo(req.CommID.OperationID, "GetFriendsInfo ok ", resp)
//// return &resp, nil
////
//}