You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
623 lines
25 KiB
623 lines
25 KiB
package notification
|
|
|
|
import (
|
|
"Open_IM/internal/rpc/msg"
|
|
"Open_IM/pkg/common/config"
|
|
"Open_IM/pkg/common/constant"
|
|
imdb "Open_IM/pkg/common/db/mysql_model/im_mysql_model"
|
|
"Open_IM/pkg/common/log"
|
|
"Open_IM/pkg/common/tokenverify"
|
|
utils2 "Open_IM/pkg/common/utils"
|
|
pbGroup "Open_IM/pkg/proto/group"
|
|
"Open_IM/pkg/proto/sdkws"
|
|
"Open_IM/pkg/utils"
|
|
"context"
|
|
"github.com/golang/protobuf/jsonpb"
|
|
"github.com/golang/protobuf/proto"
|
|
"google.golang.org/protobuf/types/known/wrapperspb"
|
|
)
|
|
|
|
//message GroupCreatedTips{
|
|
// GroupInfo Group = 1;
|
|
// GroupMemberFullInfo Creator = 2;
|
|
// repeated GroupMemberFullInfo MemberList = 3;
|
|
// uint64 OperationTime = 4;
|
|
//} creator->group
|
|
|
|
func setOpUserInfo(opUserID, groupID string, groupMemberInfo *sdkws.GroupMemberFullInfo) error {
|
|
if tokenverify.IsManagerUserID(opUserID) {
|
|
u, err := imdb.GetUserByUserID(opUserID)
|
|
if err != nil {
|
|
return utils.Wrap(err, "GetUserByUserID failed")
|
|
}
|
|
utils.CopyStructFields(groupMemberInfo, u)
|
|
groupMemberInfo.GroupID = groupID
|
|
} else {
|
|
u, err := imdb.GetGroupMemberInfoByGroupIDAndUserID(groupID, opUserID)
|
|
if err == nil {
|
|
if err = utils2.GroupMemberDBCopyOpenIM(groupMemberInfo, u); err != nil {
|
|
return utils.Wrap(err, "")
|
|
}
|
|
}
|
|
user, err := imdb.GetUserByUserID(opUserID)
|
|
if err != nil {
|
|
return utils.Wrap(err, "")
|
|
}
|
|
groupMemberInfo.GroupID = groupID
|
|
groupMemberInfo.UserID = user.UserID
|
|
groupMemberInfo.Nickname = user.Nickname
|
|
groupMemberInfo.AppMangerLevel = user.AppMangerLevel
|
|
groupMemberInfo.FaceURL = user.FaceURL
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func setGroupInfo(groupID string, groupInfo *sdkws.GroupInfo) error {
|
|
group, err := imdb.GetGroupInfoByGroupID(groupID)
|
|
if err != nil {
|
|
return utils.Wrap(err, "GetGroupInfoByGroupID failed")
|
|
}
|
|
err = utils2.GroupDBCopyOpenIM(groupInfo, group)
|
|
if err != nil {
|
|
log.NewWarn("", "GroupDBCopyOpenIM failed ", groupID, err.Error())
|
|
return nil
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func setGroupMemberInfo(groupID, userID string, groupMemberInfo *sdkws.GroupMemberFullInfo) error {
|
|
groupMember, err := imdb.GetGroupMemberInfoByGroupIDAndUserID(groupID, userID)
|
|
if err == nil {
|
|
return utils.Wrap(utils2.GroupMemberDBCopyOpenIM(groupMemberInfo, groupMember), "")
|
|
}
|
|
|
|
user, err := imdb.GetUserByUserID(userID)
|
|
if err != nil {
|
|
return utils.Wrap(err, "")
|
|
}
|
|
groupMemberInfo.GroupID = groupID
|
|
groupMemberInfo.UserID = user.UserID
|
|
groupMemberInfo.Nickname = user.Nickname
|
|
groupMemberInfo.AppMangerLevel = user.AppMangerLevel
|
|
groupMemberInfo.FaceURL = user.FaceURL
|
|
return nil
|
|
}
|
|
|
|
func setGroupOwnerInfo(groupID string, groupMemberInfo *sdkws.GroupMemberFullInfo) error {
|
|
groupMember, err := imdb.GetGroupOwnerInfoByGroupID(groupID)
|
|
if err != nil {
|
|
return utils.Wrap(err, "")
|
|
}
|
|
if err = utils2.GroupMemberDBCopyOpenIM(groupMemberInfo, groupMember); err != nil {
|
|
return utils.Wrap(err, "")
|
|
}
|
|
return nil
|
|
}
|
|
|
|
func setPublicUserInfo(userID string, publicUserInfo *sdkws.PublicUserInfo) error {
|
|
user, err := imdb.GetUserByUserID(userID)
|
|
if err != nil {
|
|
return utils.Wrap(err, "")
|
|
}
|
|
utils2.UserDBCopyOpenIMPublicUser(publicUserInfo, user)
|
|
return nil
|
|
}
|
|
|
|
func groupNotification(contentType int32, m proto.Message, sendID, groupID, recvUserID, operationID string) {
|
|
log.Info(operationID, utils.GetSelfFuncName(), "args: ", contentType, sendID, groupID, recvUserID)
|
|
|
|
var err error
|
|
var tips sdkws.TipsComm
|
|
tips.Detail, err = proto.Marshal(m)
|
|
if err != nil {
|
|
log.Error(operationID, "Marshal failed ", err.Error(), m.String())
|
|
return
|
|
}
|
|
marshaler := jsonpb.Marshaler{
|
|
OrigName: true,
|
|
EnumsAsInts: false,
|
|
EmitDefaults: false,
|
|
}
|
|
|
|
tips.JsonDetail, _ = marshaler.MarshalToString(m)
|
|
var nickname string
|
|
|
|
from, err := imdb.GetUserByUserID(sendID)
|
|
if err != nil {
|
|
log.Error(operationID, "GetUserByUserID failed ", err.Error(), sendID)
|
|
}
|
|
if from != nil {
|
|
nickname = from.Nickname
|
|
}
|
|
|
|
to, err := imdb.GetUserByUserID(recvUserID)
|
|
if err != nil {
|
|
log.NewWarn(operationID, "GetUserByUserID failed ", err.Error(), recvUserID)
|
|
}
|
|
toNickname := ""
|
|
if to != nil {
|
|
toNickname = to.Nickname
|
|
}
|
|
|
|
cn := config.Config.Notification
|
|
switch contentType {
|
|
case constant.GroupCreatedNotification:
|
|
tips.DefaultTips = nickname + " " + cn.GroupCreated.DefaultTips.Tips
|
|
case constant.GroupInfoSetNotification:
|
|
tips.DefaultTips = nickname + " " + cn.GroupInfoSet.DefaultTips.Tips
|
|
case constant.JoinGroupApplicationNotification:
|
|
tips.DefaultTips = nickname + " " + cn.JoinGroupApplication.DefaultTips.Tips
|
|
case constant.MemberQuitNotification:
|
|
tips.DefaultTips = nickname + " " + cn.MemberQuit.DefaultTips.Tips
|
|
case constant.GroupApplicationAcceptedNotification: //
|
|
tips.DefaultTips = toNickname + " " + cn.GroupApplicationAccepted.DefaultTips.Tips
|
|
case constant.GroupApplicationRejectedNotification: //
|
|
tips.DefaultTips = toNickname + " " + cn.GroupApplicationRejected.DefaultTips.Tips
|
|
case constant.GroupOwnerTransferredNotification: //
|
|
tips.DefaultTips = toNickname + " " + cn.GroupOwnerTransferred.DefaultTips.Tips
|
|
case constant.MemberKickedNotification: //
|
|
tips.DefaultTips = toNickname + " " + cn.MemberKicked.DefaultTips.Tips
|
|
case constant.MemberInvitedNotification: //
|
|
tips.DefaultTips = toNickname + " " + cn.MemberInvited.DefaultTips.Tips
|
|
case constant.MemberEnterNotification:
|
|
tips.DefaultTips = toNickname + " " + cn.MemberEnter.DefaultTips.Tips
|
|
case constant.GroupDismissedNotification:
|
|
tips.DefaultTips = toNickname + "" + cn.GroupDismissed.DefaultTips.Tips
|
|
case constant.GroupMutedNotification:
|
|
tips.DefaultTips = toNickname + "" + cn.GroupMuted.DefaultTips.Tips
|
|
case constant.GroupCancelMutedNotification:
|
|
tips.DefaultTips = toNickname + "" + cn.GroupCancelMuted.DefaultTips.Tips
|
|
case constant.GroupMemberMutedNotification:
|
|
tips.DefaultTips = toNickname + "" + cn.GroupMemberMuted.DefaultTips.Tips
|
|
case constant.GroupMemberCancelMutedNotification:
|
|
tips.DefaultTips = toNickname + "" + cn.GroupMemberCancelMuted.DefaultTips.Tips
|
|
case constant.GroupMemberInfoSetNotification:
|
|
tips.DefaultTips = toNickname + "" + cn.GroupMemberInfoSet.DefaultTips.Tips
|
|
case constant.GroupMemberSetToAdminNotification:
|
|
tips.DefaultTips = toNickname + "" + cn.GroupMemberSetToAdmin.DefaultTips.Tips
|
|
case constant.GroupMemberSetToOrdinaryUserNotification:
|
|
tips.DefaultTips = toNickname + "" + cn.GroupMemberSetToOrdinary.DefaultTips.Tips
|
|
default:
|
|
log.Error(operationID, "contentType failed ", contentType)
|
|
return
|
|
}
|
|
|
|
var n msg.NotificationMsg
|
|
n.SendID = sendID
|
|
if groupID != "" {
|
|
n.RecvID = groupID
|
|
group, err := imdb.GetGroupInfoByGroupID(groupID)
|
|
if err != nil {
|
|
log.NewError(operationID, "GetGroupInfoByGroupID failed ", err.Error(), groupID)
|
|
}
|
|
switch group.GroupType {
|
|
case constant.NormalGroup:
|
|
n.SessionType = constant.GroupChatType
|
|
default:
|
|
n.SessionType = constant.SuperGroupChatType
|
|
}
|
|
} else {
|
|
n.RecvID = recvUserID
|
|
n.SessionType = constant.SingleChatType
|
|
}
|
|
n.ContentType = contentType
|
|
n.OperationID = operationID
|
|
n.Content, err = proto.Marshal(&tips)
|
|
if err != nil {
|
|
log.Error(operationID, "Marshal failed ", err.Error(), tips.String())
|
|
return
|
|
}
|
|
msg.Notification(&n)
|
|
}
|
|
|
|
// 创建群后调用
|
|
func GroupCreatedNotification(operationID, opUserID, groupID string, initMemberList []string) {
|
|
GroupCreatedTips := sdkws.GroupCreatedTips{Group: &sdkws.GroupInfo{},
|
|
OpUser: &sdkws.GroupMemberFullInfo{}, GroupOwnerUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setOpUserInfo(opUserID, groupID, GroupCreatedTips.OpUser); err != nil {
|
|
log.NewError(operationID, "setOpUserInfo failed ", err.Error(), opUserID, groupID, GroupCreatedTips.OpUser)
|
|
return
|
|
}
|
|
err := setGroupInfo(groupID, GroupCreatedTips.Group)
|
|
if err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", groupID, GroupCreatedTips.Group)
|
|
return
|
|
}
|
|
imdb.GetGroupOwnerInfoByGroupID(groupID)
|
|
if err := setGroupOwnerInfo(groupID, GroupCreatedTips.GroupOwnerUser); err != nil {
|
|
log.Error(operationID, "setGroupOwnerInfo failed", err.Error(), groupID)
|
|
return
|
|
}
|
|
for _, v := range initMemberList {
|
|
var groupMemberInfo sdkws.GroupMemberFullInfo
|
|
if err := setGroupMemberInfo(groupID, v, &groupMemberInfo); err != nil {
|
|
log.Error(operationID, "setGroupMemberInfo failed ", err.Error(), groupID, v)
|
|
continue
|
|
}
|
|
GroupCreatedTips.MemberList = append(GroupCreatedTips.MemberList, &groupMemberInfo)
|
|
if len(GroupCreatedTips.MemberList) == constant.MaxNotificationNum {
|
|
break
|
|
}
|
|
}
|
|
groupNotification(constant.GroupCreatedNotification, &GroupCreatedTips, opUserID, groupID, "", operationID)
|
|
}
|
|
|
|
// 群信息改变后掉用
|
|
// groupName := ""
|
|
//
|
|
// notification := ""
|
|
// introduction := ""
|
|
// faceURL := ""
|
|
func GroupInfoSetNotification(operationID, opUserID, groupID string, groupName, notification, introduction, faceURL string, needVerification *wrapperspb.Int32Value) {
|
|
GroupInfoChangedTips := sdkws.GroupInfoSetTips{Group: &sdkws.GroupInfo{}, OpUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(groupID, GroupInfoChangedTips.Group); err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", err.Error(), groupID)
|
|
return
|
|
}
|
|
GroupInfoChangedTips.Group.GroupName = groupName
|
|
GroupInfoChangedTips.Group.Notification = notification
|
|
GroupInfoChangedTips.Group.Introduction = introduction
|
|
GroupInfoChangedTips.Group.FaceURL = faceURL
|
|
if needVerification != nil {
|
|
GroupInfoChangedTips.Group.NeedVerification = needVerification.Value
|
|
}
|
|
|
|
if err := setOpUserInfo(opUserID, groupID, GroupInfoChangedTips.OpUser); err != nil {
|
|
log.Error(operationID, "setOpUserInfo failed ", err.Error(), opUserID, groupID)
|
|
return
|
|
}
|
|
groupNotification(constant.GroupInfoSetNotification, &GroupInfoChangedTips, opUserID, groupID, "", operationID)
|
|
}
|
|
|
|
func GroupMutedNotification(operationID, opUserID, groupID string) {
|
|
tips := sdkws.GroupMutedTips{Group: &sdkws.GroupInfo{},
|
|
OpUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(groupID, tips.Group); err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", err.Error(), groupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(opUserID, groupID, tips.OpUser); err != nil {
|
|
log.Error(operationID, "setOpUserInfo failed ", err.Error(), opUserID, groupID)
|
|
return
|
|
}
|
|
groupNotification(constant.GroupMutedNotification, &tips, opUserID, groupID, "", operationID)
|
|
}
|
|
|
|
func GroupCancelMutedNotification(operationID, opUserID, groupID string) {
|
|
tips := sdkws.GroupCancelMutedTips{Group: &sdkws.GroupInfo{},
|
|
OpUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(groupID, tips.Group); err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", err.Error(), groupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(opUserID, groupID, tips.OpUser); err != nil {
|
|
log.Error(operationID, "setOpUserInfo failed ", err.Error(), opUserID, groupID)
|
|
return
|
|
}
|
|
groupNotification(constant.GroupCancelMutedNotification, &tips, opUserID, groupID, "", operationID)
|
|
}
|
|
|
|
func GroupMemberMutedNotification(operationID, opUserID, groupID, groupMemberUserID string, mutedSeconds uint32) {
|
|
tips := sdkws.GroupMemberMutedTips{Group: &sdkws.GroupInfo{},
|
|
OpUser: &sdkws.GroupMemberFullInfo{}, MutedUser: &sdkws.GroupMemberFullInfo{}}
|
|
tips.MutedSeconds = mutedSeconds
|
|
if err := setGroupInfo(groupID, tips.Group); err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", err.Error(), groupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(opUserID, groupID, tips.OpUser); err != nil {
|
|
log.Error(operationID, "setOpUserInfo failed ", err.Error(), opUserID, groupID)
|
|
return
|
|
}
|
|
if err := setGroupMemberInfo(groupID, groupMemberUserID, tips.MutedUser); err != nil {
|
|
log.Error(operationID, "setGroupMemberInfo failed ", err.Error(), groupID, groupMemberUserID)
|
|
return
|
|
}
|
|
groupNotification(constant.GroupMemberMutedNotification, &tips, opUserID, groupID, "", operationID)
|
|
}
|
|
|
|
func GroupMemberInfoSetNotification(operationID, opUserID, groupID, groupMemberUserID string) {
|
|
tips := sdkws.GroupMemberInfoSetTips{Group: &sdkws.GroupInfo{},
|
|
OpUser: &sdkws.GroupMemberFullInfo{}, ChangedUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(groupID, tips.Group); err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", err.Error(), groupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(opUserID, groupID, tips.OpUser); err != nil {
|
|
log.Error(operationID, "setOpUserInfo failed ", err.Error(), opUserID, groupID)
|
|
return
|
|
}
|
|
if err := setGroupMemberInfo(groupID, groupMemberUserID, tips.ChangedUser); err != nil {
|
|
log.Error(operationID, "setGroupMemberInfo failed ", err.Error(), groupID, groupMemberUserID)
|
|
return
|
|
}
|
|
groupNotification(constant.GroupMemberInfoSetNotification, &tips, opUserID, groupID, "", operationID)
|
|
}
|
|
|
|
func GroupMemberRoleLevelChangeNotification(operationID, opUserID, groupID, groupMemberUserID string, notificationType int32) {
|
|
if notificationType != constant.GroupMemberSetToAdminNotification && notificationType != constant.GroupMemberSetToOrdinaryUserNotification {
|
|
log.NewError(operationID, utils.GetSelfFuncName(), "invalid notificationType: ", notificationType)
|
|
return
|
|
}
|
|
tips := sdkws.GroupMemberInfoSetTips{Group: &sdkws.GroupInfo{},
|
|
OpUser: &sdkws.GroupMemberFullInfo{}, ChangedUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(groupID, tips.Group); err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", err.Error(), groupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(opUserID, groupID, tips.OpUser); err != nil {
|
|
log.Error(operationID, "setOpUserInfo failed ", err.Error(), opUserID, groupID)
|
|
return
|
|
}
|
|
if err := setGroupMemberInfo(groupID, groupMemberUserID, tips.ChangedUser); err != nil {
|
|
log.Error(operationID, "setGroupMemberInfo failed ", err.Error(), groupID, groupMemberUserID)
|
|
return
|
|
}
|
|
groupNotification(notificationType, &tips, opUserID, groupID, "", operationID)
|
|
}
|
|
|
|
func GroupMemberCancelMutedNotification(operationID, opUserID, groupID, groupMemberUserID string) {
|
|
tips := sdkws.GroupMemberCancelMutedTips{Group: &sdkws.GroupInfo{},
|
|
OpUser: &sdkws.GroupMemberFullInfo{}, MutedUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(groupID, tips.Group); err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", err.Error(), groupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(opUserID, groupID, tips.OpUser); err != nil {
|
|
log.Error(operationID, "setOpUserInfo failed ", err.Error(), opUserID, groupID)
|
|
return
|
|
}
|
|
if err := setGroupMemberInfo(groupID, groupMemberUserID, tips.MutedUser); err != nil {
|
|
log.Error(operationID, "setGroupMemberInfo failed ", err.Error(), groupID, groupMemberUserID)
|
|
return
|
|
}
|
|
groupNotification(constant.GroupMemberCancelMutedNotification, &tips, opUserID, groupID, "", operationID)
|
|
}
|
|
|
|
// message ReceiveJoinApplicationTips{
|
|
// GroupInfo Group = 1;
|
|
// PublicUserInfo Applicant = 2;
|
|
// string Reason = 3;
|
|
// } apply->all managers GroupID string `protobuf:"bytes,1,opt,name=GroupID" json:"GroupID,omitempty"`
|
|
//
|
|
// ReqMessage string `protobuf:"bytes,2,opt,name=ReqMessage" json:"ReqMessage,omitempty"`
|
|
// OpUserID string `protobuf:"bytes,3,opt,name=OpUserID" json:"OpUserID,omitempty"`
|
|
// OperationID string `protobuf:"bytes,4,opt,name=OperationID" json:"OperationID,omitempty"`
|
|
//
|
|
// 申请进群后调用
|
|
func JoinGroupApplicationNotification(ctx context.Context, req *pbGroup.JoinGroupReq) {
|
|
JoinGroupApplicationTips := sdkws.JoinGroupApplicationTips{Group: &sdkws.GroupInfo{}, Applicant: &sdkws.PublicUserInfo{}}
|
|
err := setGroupInfo(req.GroupID, JoinGroupApplicationTips.Group)
|
|
if err != nil {
|
|
log.Error(utils.OperationID(ctx), "setGroupInfo failed ", err.Error(), req.GroupID)
|
|
return
|
|
}
|
|
if err = setPublicUserInfo(utils.OpUserID(ctx), JoinGroupApplicationTips.Applicant); err != nil {
|
|
log.Error(utils.OperationID(ctx), "setPublicUserInfo failed ", err.Error(), utils.OpUserID(ctx))
|
|
return
|
|
}
|
|
JoinGroupApplicationTips.ReqMsg = req.ReqMessage
|
|
|
|
managerList, err := imdb.GetOwnerManagerByGroupID(req.GroupID)
|
|
if err != nil {
|
|
log.NewError(utils.OperationID(ctx), "GetOwnerManagerByGroupId failed ", err.Error(), req.GroupID)
|
|
return
|
|
}
|
|
for _, v := range managerList {
|
|
groupNotification(constant.JoinGroupApplicationNotification, &JoinGroupApplicationTips, utils.OpUserID(ctx), "", v.UserID, utils.OperationID(ctx))
|
|
log.NewInfo(utils.OperationID(ctx), "Notification ", v)
|
|
}
|
|
}
|
|
|
|
func MemberQuitNotification(req *pbGroup.QuitGroupReq) {
|
|
MemberQuitTips := sdkws.MemberQuitTips{Group: &sdkws.GroupInfo{}, QuitUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(req.GroupID, MemberQuitTips.Group); err != nil {
|
|
log.Error(req.OperationID, "setGroupInfo failed ", err.Error(), req.GroupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(req.OpUserID, req.GroupID, MemberQuitTips.QuitUser); err != nil {
|
|
log.Error(req.OperationID, "setOpUserInfo failed ", err.Error(), req.OpUserID, req.GroupID)
|
|
return
|
|
}
|
|
|
|
groupNotification(constant.MemberQuitNotification, &MemberQuitTips, req.OpUserID, req.GroupID, "", req.OperationID)
|
|
}
|
|
|
|
// message ApplicationProcessedTips{
|
|
// GroupInfo Group = 1;
|
|
// GroupMemberFullInfo OpUser = 2;
|
|
// int32 Result = 3;
|
|
// string Reason = 4;
|
|
// }
|
|
//
|
|
// 处理进群请求后调用
|
|
func GroupApplicationAcceptedNotification(req *pbGroup.GroupApplicationResponseReq) {
|
|
GroupApplicationAcceptedTips := sdkws.GroupApplicationAcceptedTips{Group: &sdkws.GroupInfo{}, OpUser: &sdkws.GroupMemberFullInfo{}, HandleMsg: req.HandledMsg}
|
|
if err := setGroupInfo(req.GroupID, GroupApplicationAcceptedTips.Group); err != nil {
|
|
log.NewError(req.OperationID, "setGroupInfo failed ", err.Error(), req.GroupID, GroupApplicationAcceptedTips.Group)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(req.OpUserID, req.GroupID, GroupApplicationAcceptedTips.OpUser); err != nil {
|
|
log.Error(req.OperationID, "setOpUserInfo failed", req.OpUserID, req.GroupID, GroupApplicationAcceptedTips.OpUser)
|
|
return
|
|
}
|
|
|
|
groupNotification(constant.GroupApplicationAcceptedNotification, &GroupApplicationAcceptedTips, req.OpUserID, "", req.FromUserID, req.OperationID)
|
|
adminList, err := imdb.GetOwnerManagerByGroupID(req.GroupID)
|
|
if err != nil {
|
|
log.Error(req.OperationID, "GetOwnerManagerByGroupID failed", req.GroupID)
|
|
return
|
|
}
|
|
for _, v := range adminList {
|
|
if v.UserID == req.OpUserID {
|
|
continue
|
|
}
|
|
GroupApplicationAcceptedTips.ReceiverAs = 1
|
|
groupNotification(constant.GroupApplicationAcceptedNotification, &GroupApplicationAcceptedTips, req.OpUserID, "", v.UserID, req.OperationID)
|
|
}
|
|
}
|
|
|
|
func GroupApplicationRejectedNotification(req *pbGroup.GroupApplicationResponseReq) {
|
|
GroupApplicationRejectedTips := sdkws.GroupApplicationRejectedTips{Group: &sdkws.GroupInfo{}, OpUser: &sdkws.GroupMemberFullInfo{}, HandleMsg: req.HandledMsg}
|
|
if err := setGroupInfo(req.GroupID, GroupApplicationRejectedTips.Group); err != nil {
|
|
log.NewError(req.OperationID, "setGroupInfo failed ", err.Error(), req.GroupID, GroupApplicationRejectedTips.Group)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(req.OpUserID, req.GroupID, GroupApplicationRejectedTips.OpUser); err != nil {
|
|
log.Error(req.OperationID, "setOpUserInfo failed", req.OpUserID, req.GroupID, GroupApplicationRejectedTips.OpUser)
|
|
return
|
|
}
|
|
groupNotification(constant.GroupApplicationRejectedNotification, &GroupApplicationRejectedTips, req.OpUserID, "", req.FromUserID, req.OperationID)
|
|
adminList, err := imdb.GetOwnerManagerByGroupID(req.GroupID)
|
|
if err != nil {
|
|
log.Error(req.OperationID, "GetOwnerManagerByGroupID failed", req.GroupID)
|
|
return
|
|
}
|
|
for _, v := range adminList {
|
|
if v.UserID == req.OpUserID {
|
|
continue
|
|
}
|
|
GroupApplicationRejectedTips.ReceiverAs = 1
|
|
groupNotification(constant.GroupApplicationRejectedNotification, &GroupApplicationRejectedTips, req.OpUserID, "", v.UserID, req.OperationID)
|
|
}
|
|
}
|
|
|
|
func GroupOwnerTransferredNotification(req *pbGroup.TransferGroupOwnerReq) {
|
|
GroupOwnerTransferredTips := sdkws.GroupOwnerTransferredTips{Group: &sdkws.GroupInfo{}, OpUser: &sdkws.GroupMemberFullInfo{}, NewGroupOwner: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(req.GroupID, GroupOwnerTransferredTips.Group); err != nil {
|
|
log.NewError(req.OperationID, "setGroupInfo failed ", err.Error(), req.GroupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(req.OpUserID, req.GroupID, GroupOwnerTransferredTips.OpUser); err != nil {
|
|
log.Error(req.OperationID, "setOpUserInfo failed", req.OpUserID, req.GroupID)
|
|
return
|
|
}
|
|
if err := setGroupMemberInfo(req.GroupID, req.NewOwnerUserID, GroupOwnerTransferredTips.NewGroupOwner); err != nil {
|
|
log.Error(req.OperationID, "setGroupMemberInfo failed", req.GroupID, req.NewOwnerUserID)
|
|
return
|
|
}
|
|
groupNotification(constant.GroupOwnerTransferredNotification, &GroupOwnerTransferredTips, req.OpUserID, req.GroupID, "", req.OperationID)
|
|
}
|
|
|
|
func GroupDismissedNotification(req *pbGroup.DismissGroupReq) {
|
|
tips := sdkws.GroupDismissedTips{Group: &sdkws.GroupInfo{}, OpUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(req.GroupID, tips.Group); err != nil {
|
|
log.NewError(req.OperationID, "setGroupInfo failed ", err.Error(), req.GroupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(req.OpUserID, req.GroupID, tips.OpUser); err != nil {
|
|
log.Error(req.OperationID, "setOpUserInfo failed", req.OpUserID, req.GroupID)
|
|
return
|
|
}
|
|
groupNotification(constant.GroupDismissedNotification, &tips, req.OpUserID, req.GroupID, "", req.OperationID)
|
|
}
|
|
|
|
// message MemberKickedTips{
|
|
// GroupInfo Group = 1;
|
|
// GroupMemberFullInfo OpUser = 2;
|
|
// GroupMemberFullInfo KickedUser = 3;
|
|
// uint64 OperationTime = 4;
|
|
// }
|
|
//
|
|
// 被踢后调用
|
|
func MemberKickedNotification(req *pbGroup.KickGroupMemberReq, kickedUserIDList []string) {
|
|
MemberKickedTips := sdkws.MemberKickedTips{Group: &sdkws.GroupInfo{}, OpUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(req.GroupID, MemberKickedTips.Group); err != nil {
|
|
log.Error(req.OperationID, "setGroupInfo failed ", err.Error(), req.GroupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(req.OpUserID, req.GroupID, MemberKickedTips.OpUser); err != nil {
|
|
log.Error(req.OperationID, "setOpUserInfo failed ", err.Error(), req.OpUserID)
|
|
return
|
|
}
|
|
for _, v := range kickedUserIDList {
|
|
var groupMemberInfo sdkws.GroupMemberFullInfo
|
|
if err := setGroupMemberInfo(req.GroupID, v, &groupMemberInfo); err != nil {
|
|
log.Error(req.OperationID, "setGroupMemberInfo failed ", err.Error(), req.GroupID, v)
|
|
continue
|
|
}
|
|
MemberKickedTips.KickedUserList = append(MemberKickedTips.KickedUserList, &groupMemberInfo)
|
|
}
|
|
groupNotification(constant.MemberKickedNotification, &MemberKickedTips, req.OpUserID, req.GroupID, "", req.OperationID)
|
|
//
|
|
//for _, v := range kickedUserIDList {
|
|
// groupNotification(constant.MemberKickedNotification, &MemberKickedTips, req.OpUserID, "", v, req.OperationID)
|
|
//}
|
|
}
|
|
|
|
// message MemberInvitedTips{
|
|
// GroupInfo Group = 1;
|
|
// GroupMemberFullInfo OpUser = 2;
|
|
// GroupMemberFullInfo InvitedUser = 3;
|
|
// uint64 OperationTime = 4;
|
|
// }
|
|
//
|
|
// 被邀请进群后调用
|
|
func MemberInvitedNotification(operationID, groupID, opUserID, reason string, invitedUserIDList []string) {
|
|
MemberInvitedTips := sdkws.MemberInvitedTips{Group: &sdkws.GroupInfo{}, OpUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(groupID, MemberInvitedTips.Group); err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", err.Error(), groupID)
|
|
return
|
|
}
|
|
if err := setOpUserInfo(opUserID, groupID, MemberInvitedTips.OpUser); err != nil {
|
|
log.Error(operationID, "setOpUserInfo failed ", err.Error(), opUserID, groupID)
|
|
return
|
|
}
|
|
for _, v := range invitedUserIDList {
|
|
var groupMemberInfo sdkws.GroupMemberFullInfo
|
|
if err := setGroupMemberInfo(groupID, v, &groupMemberInfo); err != nil {
|
|
log.Error(operationID, "setGroupMemberInfo failed ", err.Error(), groupID)
|
|
continue
|
|
}
|
|
MemberInvitedTips.InvitedUserList = append(MemberInvitedTips.InvitedUserList, &groupMemberInfo)
|
|
}
|
|
groupNotification(constant.MemberInvitedNotification, &MemberInvitedTips, opUserID, groupID, "", operationID)
|
|
}
|
|
|
|
//message GroupInfoChangedTips{
|
|
// int32 ChangedType = 1; //bitwise operators: 1:groupName; 10:Notification 100:Introduction; 1000:FaceUrl
|
|
// GroupInfo Group = 2;
|
|
// GroupMemberFullInfo OpUser = 3;
|
|
//}
|
|
|
|
//message MemberLeaveTips{
|
|
// GroupInfo Group = 1;
|
|
// GroupMemberFullInfo LeaverUser = 2;
|
|
// uint64 OperationTime = 3;
|
|
//}
|
|
|
|
//群成员退群后调用
|
|
|
|
// message MemberEnterTips{
|
|
// GroupInfo Group = 1;
|
|
// GroupMemberFullInfo EntrantUser = 2;
|
|
// uint64 OperationTime = 3;
|
|
// }
|
|
//
|
|
// 群成员主动申请进群,管理员同意后调用,
|
|
func MemberEnterNotification(ctx context.Context, req *pbGroup.GroupApplicationResponseReq) {
|
|
MemberEnterTips := sdkws.MemberEnterTips{Group: &sdkws.GroupInfo{}, EntrantUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(req.GroupID, MemberEnterTips.Group); err != nil {
|
|
log.Error(req.OperationID, "setGroupInfo failed ", err.Error(), req.GroupID, MemberEnterTips.Group)
|
|
return
|
|
}
|
|
if err := setGroupMemberInfo(req.GroupID, req.FromUserID, MemberEnterTips.EntrantUser); err != nil {
|
|
log.Error(req.OperationID, "setGroupMemberInfo failed ", err.Error(), req.OpUserID, req.GroupID, MemberEnterTips.EntrantUser)
|
|
return
|
|
}
|
|
groupNotification(constant.MemberEnterNotification, &MemberEnterTips, req.OpUserID, req.GroupID, "", req.OperationID)
|
|
}
|
|
|
|
func MemberEnterDirectlyNotification(groupID string, entrantUserID string, operationID string) {
|
|
MemberEnterTips := sdkws.MemberEnterTips{Group: &sdkws.GroupInfo{}, EntrantUser: &sdkws.GroupMemberFullInfo{}}
|
|
if err := setGroupInfo(groupID, MemberEnterTips.Group); err != nil {
|
|
log.Error(operationID, "setGroupInfo failed ", err.Error(), groupID, MemberEnterTips.Group)
|
|
return
|
|
}
|
|
if err := setGroupMemberInfo(groupID, entrantUserID, MemberEnterTips.EntrantUser); err != nil {
|
|
log.Error(operationID, "setGroupMemberInfo failed ", err.Error(), groupID, entrantUserID, MemberEnterTips.EntrantUser)
|
|
return
|
|
}
|
|
groupNotification(constant.MemberEnterNotification, &MemberEnterTips, entrantUserID, groupID, "", operationID)
|
|
}
|