Files
open-im-server/internal/rpc/msg/friend_notification.go
T

174 lines
7.7 KiB
Go
Raw Normal View History

2022-01-14 13:44:46 +08:00
package msg
import (
2023-01-31 21:06:04 +08:00
"Open_IM/internal/common/check"
2022-01-16 12:25:41 +08:00
"Open_IM/pkg/common/config"
2022-01-14 13:44:46 +08:00
"Open_IM/pkg/common/constant"
"Open_IM/pkg/common/log"
2023-02-01 11:15:39 +08:00
"Open_IM/pkg/common/tracelog"
2022-01-14 13:44:46 +08:00
pbFriend "Open_IM/pkg/proto/friend"
open_im_sdk "Open_IM/pkg/proto/sdk_ws"
"Open_IM/pkg/utils"
2023-01-31 21:06:04 +08:00
"context"
2022-02-10 18:32:02 +08:00
"github.com/golang/protobuf/jsonpb"
2022-01-15 11:14:29 +08:00
"github.com/golang/protobuf/proto"
2022-01-14 13:44:46 +08:00
)
2022-01-14 16:48:42 +08:00
func getFromToUserNickname(fromUserID, toUserID string) (string, string, error) {
2023-01-31 21:06:04 +08:00
users, err := check.GetUsersInfo(context.Background(), fromUserID, toUserID)
2022-01-14 16:48:42 +08:00
if err != nil {
2023-01-31 21:06:04 +08:00
return "", "", nil
2022-01-14 13:44:46 +08:00
}
2023-01-31 21:06:04 +08:00
if users[0].UserID == fromUserID {
return users[0].Nickname, users[1].Nickname, nil
2022-01-14 13:44:46 +08:00
}
2023-01-31 21:06:04 +08:00
return users[1].Nickname, users[0].Nickname, nil
2022-01-14 13:44:46 +08:00
}
2023-01-30 10:40:27 +08:00
func friendNotification(operationID, fromUserID, toUserID string, contentType int32, m proto.Message) {
2023-01-31 21:06:04 +08:00
log.Info(operationID, utils.GetSelfFuncName(), "args: ", contentType)
2022-01-16 12:25:41 +08:00
var err error
var tips open_im_sdk.TipsComm
tips.Detail, err = proto.Marshal(m)
2022-01-14 16:48:42 +08:00
if err != nil {
2023-01-30 10:40:27 +08:00
log.Error(operationID, "Marshal failed ", err.Error(), m.String())
2022-01-14 16:48:42 +08:00
return
}
2022-01-16 12:25:41 +08:00
2022-02-10 18:32:02 +08:00
marshaler := jsonpb.Marshaler{
OrigName: true,
EnumsAsInts: false,
EmitDefaults: false,
}
tips.JsonDetail, _ = marshaler.MarshalToString(m)
2023-01-30 10:40:27 +08:00
fromUserNickname, toUserNickname, err := getFromToUserNickname(fromUserID, toUserID)
2022-01-15 18:36:40 +08:00
if err != nil {
2023-01-30 10:40:27 +08:00
log.Error(operationID, "getFromToUserNickname failed ", err.Error(), fromUserID, toUserID)
2022-01-16 12:25:41 +08:00
return
}
cn := config.Config.Notification
switch contentType {
2022-01-16 16:31:28 +08:00
case constant.FriendApplicationNotification:
2022-01-17 10:11:26 +08:00
tips.DefaultTips = fromUserNickname + cn.FriendApplication.DefaultTips.Tips
2022-01-16 12:25:41 +08:00
case constant.FriendApplicationApprovedNotification:
tips.DefaultTips = fromUserNickname + cn.FriendApplicationApproved.DefaultTips.Tips
case constant.FriendApplicationRejectedNotification:
tips.DefaultTips = fromUserNickname + cn.FriendApplicationRejected.DefaultTips.Tips
case constant.FriendAddedNotification:
tips.DefaultTips = cn.FriendAdded.DefaultTips.Tips
case constant.FriendDeletedNotification:
tips.DefaultTips = cn.FriendDeleted.DefaultTips.Tips + toUserNickname
2022-01-16 16:31:28 +08:00
case constant.FriendRemarkSetNotification:
2022-01-17 10:11:26 +08:00
tips.DefaultTips = fromUserNickname + cn.FriendRemarkSet.DefaultTips.Tips
2022-01-16 12:25:41 +08:00
case constant.BlackAddedNotification:
2022-02-08 14:50:47 +08:00
tips.DefaultTips = cn.BlackAdded.DefaultTips.Tips
2022-01-16 12:25:41 +08:00
case constant.BlackDeletedNotification:
tips.DefaultTips = cn.BlackDeleted.DefaultTips.Tips + toUserNickname
2022-02-10 09:17:48 +08:00
case constant.UserInfoUpdatedNotification:
tips.DefaultTips = cn.UserInfoUpdated.DefaultTips.Tips
2022-12-07 10:00:53 +08:00
case constant.FriendInfoUpdatedNotification:
tips.DefaultTips = cn.FriendInfoUpdated.DefaultTips.Tips + toUserNickname
2022-01-16 12:25:41 +08:00
default:
2023-01-30 10:40:27 +08:00
log.Error(operationID, "contentType failed ", contentType)
2022-01-15 18:36:40 +08:00
return
}
2022-01-14 13:44:46 +08:00
var n NotificationMsg
2023-01-30 10:40:27 +08:00
n.SendID = fromUserID
n.RecvID = toUserID
2022-01-16 12:25:41 +08:00
n.ContentType = contentType
2022-01-14 13:44:46 +08:00
n.SessionType = constant.SingleChatType
n.MsgFrom = constant.SysMsgType
2023-01-30 10:40:27 +08:00
n.OperationID = operationID
2022-01-15 18:36:40 +08:00
n.Content, err = proto.Marshal(&tips)
if err != nil {
2023-01-30 10:40:27 +08:00
log.Error(operationID, "Marshal failed ", err.Error(), tips.String())
2022-01-15 18:36:40 +08:00
return
}
2022-01-14 16:48:42 +08:00
Notification(&n)
}
2022-01-14 13:44:46 +08:00
2023-02-07 20:28:34 +08:00
func FriendApplicationAddNotification(ctx context.Context, req *pbFriend.AddFriendReq) {
2022-01-17 10:11:26 +08:00
FriendApplicationTips := open_im_sdk.FriendApplicationTips{FromToUserID: &open_im_sdk.FromToUserID{}}
2023-01-31 21:06:04 +08:00
FriendApplicationTips.FromToUserID.FromUserID = req.FromUserID
FriendApplicationTips.FromToUserID.ToUserID = req.ToUserID
2023-02-01 11:15:39 +08:00
friendNotification(tracelog.GetOperationID(ctx), req.FromUserID, req.ToUserID, constant.FriendApplicationNotification, &FriendApplicationTips)
2022-01-16 12:25:41 +08:00
}
2023-02-07 20:28:34 +08:00
func FriendApplicationAgreedNotification(ctx context.Context, req *pbFriend.RespondFriendApplyReq) {
2022-01-16 16:31:28 +08:00
FriendApplicationApprovedTips := open_im_sdk.FriendApplicationApprovedTips{FromToUserID: &open_im_sdk.FromToUserID{}}
2023-01-31 21:06:04 +08:00
FriendApplicationApprovedTips.FromToUserID.FromUserID = req.FromUserID
FriendApplicationApprovedTips.FromToUserID.ToUserID = req.ToUserID
2022-01-16 16:31:28 +08:00
FriendApplicationApprovedTips.HandleMsg = req.HandleMsg
2023-02-01 11:15:39 +08:00
friendNotification(tracelog.GetOperationID(ctx), req.ToUserID, req.FromUserID, constant.FriendApplicationApprovedNotification, &FriendApplicationApprovedTips)
2022-01-14 16:48:42 +08:00
}
2022-01-14 13:44:46 +08:00
2023-02-07 20:28:34 +08:00
func FriendApplicationRefusedNotification(ctx context.Context, req *pbFriend.RespondFriendApplyReq) {
2022-01-16 16:31:28 +08:00
FriendApplicationApprovedTips := open_im_sdk.FriendApplicationApprovedTips{FromToUserID: &open_im_sdk.FromToUserID{}}
2023-01-31 21:06:04 +08:00
FriendApplicationApprovedTips.FromToUserID.FromUserID = req.FromUserID
FriendApplicationApprovedTips.FromToUserID.ToUserID = req.ToUserID
2022-01-16 16:31:28 +08:00
FriendApplicationApprovedTips.HandleMsg = req.HandleMsg
2023-02-01 11:15:39 +08:00
friendNotification(tracelog.GetOperationID(ctx), req.ToUserID, req.FromUserID, constant.FriendApplicationRejectedNotification, &FriendApplicationApprovedTips)
2022-01-16 16:31:28 +08:00
}
2023-02-01 10:49:30 +08:00
func FriendAddedNotification(ctx context.Context, operationID, opUserID, fromUserID, toUserID string) {
2022-01-17 10:11:26 +08:00
friendAddedTips := open_im_sdk.FriendAddedTips{Friend: &open_im_sdk.FriendInfo{}, OpUser: &open_im_sdk.PublicUserInfo{}}
2023-02-01 10:49:30 +08:00
user, err := check.GetUsersInfo(context.Background(), opUserID)
2022-01-14 13:44:46 +08:00
if err != nil {
2022-01-14 16:48:42 +08:00
return
2022-01-14 13:44:46 +08:00
}
2023-02-01 10:49:30 +08:00
friendAddedTips.OpUser.UserID = user[0].UserID
friendAddedTips.OpUser.Ex = user[0].Ex
friendAddedTips.OpUser.Nickname = user[0].Nickname
friendAddedTips.OpUser.FaceURL = user[0].FaceURL
friend, err := check.GetFriendsInfo(ctx, fromUserID, toUserID)
2022-01-14 13:44:46 +08:00
if err != nil {
2022-01-14 16:48:42 +08:00
return
2022-01-14 13:44:46 +08:00
}
2023-02-01 10:49:30 +08:00
friendAddedTips.Friend = friend
2023-01-31 21:06:04 +08:00
friendNotification(operationID, fromUserID, toUserID, constant.FriendAddedNotification, &friendAddedTips)
2022-01-14 13:44:46 +08:00
}
2023-02-01 11:15:39 +08:00
func FriendDeletedNotification(ctx context.Context, req *pbFriend.DeleteFriendReq) {
2022-01-17 10:11:26 +08:00
friendDeletedTips := open_im_sdk.FriendDeletedTips{FromToUserID: &open_im_sdk.FromToUserID{}}
2023-01-31 21:06:04 +08:00
friendDeletedTips.FromToUserID.FromUserID = req.OwnerUserID
friendDeletedTips.FromToUserID.ToUserID = req.FriendUserID
2023-02-01 11:15:39 +08:00
friendNotification(tracelog.GetOperationID(ctx), req.OwnerUserID, req.FriendUserID, constant.FriendDeletedNotification, &friendDeletedTips)
2022-01-14 13:44:46 +08:00
}
2023-02-01 11:15:39 +08:00
func FriendRemarkSetNotification(ctx context.Context, fromUserID, toUserID string) {
2022-01-17 10:11:26 +08:00
friendInfoChangedTips := open_im_sdk.FriendInfoChangedTips{FromToUserID: &open_im_sdk.FromToUserID{}}
2022-01-15 18:36:40 +08:00
friendInfoChangedTips.FromToUserID.FromUserID = fromUserID
friendInfoChangedTips.FromToUserID.ToUserID = toUserID
2023-02-01 11:15:39 +08:00
friendNotification(tracelog.GetOperationID(ctx), fromUserID, toUserID, constant.FriendRemarkSetNotification, &friendInfoChangedTips)
2022-01-14 13:44:46 +08:00
}
2023-02-01 11:15:39 +08:00
func BlackAddedNotification(ctx context.Context, req *pbFriend.AddBlackReq) {
2022-01-17 10:11:26 +08:00
blackAddedTips := open_im_sdk.BlackAddedTips{FromToUserID: &open_im_sdk.FromToUserID{}}
2023-01-31 21:06:04 +08:00
blackAddedTips.FromToUserID.FromUserID = req.OwnerUserID
blackAddedTips.FromToUserID.ToUserID = req.BlackUserID
2023-02-01 11:15:39 +08:00
friendNotification(tracelog.GetOperationID(ctx), req.OwnerUserID, req.BlackUserID, constant.BlackAddedNotification, &blackAddedTips)
2022-01-14 13:44:46 +08:00
}
2023-02-01 11:15:39 +08:00
func BlackDeletedNotification(ctx context.Context, req *pbFriend.RemoveBlackReq) {
2022-01-17 10:11:26 +08:00
blackDeletedTips := open_im_sdk.BlackDeletedTips{FromToUserID: &open_im_sdk.FromToUserID{}}
2023-01-31 21:06:04 +08:00
blackDeletedTips.FromToUserID.FromUserID = req.OwnerUserID
blackDeletedTips.FromToUserID.ToUserID = req.BlackUserID
2023-02-01 11:15:39 +08:00
friendNotification(tracelog.GetOperationID(ctx), req.OwnerUserID, req.BlackUserID, constant.BlackDeletedNotification, &blackDeletedTips)
2022-01-14 13:44:46 +08:00
}
2023-01-30 10:40:27 +08:00
// send to myself
2023-02-01 11:15:39 +08:00
func UserInfoUpdatedNotification(ctx context.Context, opUserID string, changedUserID string) {
2022-12-07 10:00:53 +08:00
selfInfoUpdatedTips := open_im_sdk.UserInfoUpdatedTips{UserID: changedUserID}
2023-02-01 11:15:39 +08:00
friendNotification(tracelog.GetOperationID(ctx), opUserID, changedUserID, constant.UserInfoUpdatedNotification, &selfInfoUpdatedTips)
2022-01-14 13:44:46 +08:00
}
2022-12-07 10:00:53 +08:00
2023-02-01 11:15:39 +08:00
func FriendInfoUpdatedNotification(ctx context.Context, changedUserID string, needNotifiedUserID string, opUserID string) {
2022-12-07 10:00:53 +08:00
selfInfoUpdatedTips := open_im_sdk.UserInfoUpdatedTips{UserID: changedUserID}
2023-02-01 11:15:39 +08:00
friendNotification(tracelog.GetOperationID(ctx), opUserID, needNotifiedUserID, constant.FriendInfoUpdatedNotification, &selfInfoUpdatedTips)
2022-12-07 10:00:53 +08:00
}