mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-27 05:52:29 +08:00 
			
		
		
		
	* fix: to start im or chat, ZooKeeper must be started first. * fix: msg gateway start output err info Signed-off-by: Gordon <1432970085@qq.com> * fix: msg gateway start output err info Signed-off-by: Gordon <1432970085@qq.com> * chore: package path changes Signed-off-by: withchao <993506633@qq.com> * fix: go mod update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * chore: package path changes Signed-off-by: withchao <993506633@qq.com> * chore: package path changes Signed-off-by: withchao <993506633@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: token update Signed-off-by: Gordon <1432970085@qq.com> * fix: get all userID Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: msggateway add online status call Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * refactor: log change Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * refactor: log change Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * chore: network mode change Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * feat: add api of get server time Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * feat: remove go work sum Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * fix: pull message add isRead field Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: check msg-transfer script Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: script update Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: start don't kill old process Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * fix: check component Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: pull message set isRead only message come from single. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> * fix: multiple gateway kick user each other. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: add ex field to update group info. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change * cicd: robot automated Change * refactor: change project module name. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * refactor: change project module name. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * refactor: change project module name. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change * test: for pressure test. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * test: for pressure test. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * test: for pressure test. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * test: message log. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change * fxi: component check output valid info. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fxi: component check output valid info. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * test: send message test log. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * cicd: robot automated Change * cicd: robot automated Change * test: remove info log. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * feat: api of send message add sendTime field. Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> * fix: add callback for update user's info. * cicd: robot automated Change * fix: change callback command name. * cicd: robot automated Change * fix: single chat unread status change. * fix: single chat unread status change. * fix: single chat unread status change. * fix: user status change. * cicd: robot automated Change * fix: user status change. * fix: user status change. * fix: user status change. * cicd: robot automated Change * fix: ws close when user logout. * fix: remove repeat platform on online status. * cicd: robot automated Change * fix: api send messages for notification conversation . * fix: api send messages for notification conversation . * fix: api send messages for notification conversation . * fix: api send messages for notification conversation . * fix: api send messages for notification conversation . * fix: api send messages for notification conversation. * fix: api send messages for notification conversation. * fix: api send messages for notification conversation. * fix: api send messages for notification conversation. * fix: api send messages for notification conversation. * fix: api send messages for notification conversation. * re: remove router of unsubscribeStatus. * re: remove router of unsubscribeStatus. * re: remove router of unsubscribeStatus. * re: remove router of unsubscribeStatus. * fix: reset branch * fix: not support redis cluster. CROSSSLOT Keys in request don't hash to the same slot * fix: update user.FaceURL do not trigger GroupMemberInfoSetNotification * cicd: robot automated Change * fix: api send messages for notification conversation. * fix: api send messages for notification conversation. --------- Signed-off-by: Gordon <1432970085@qq.com> Signed-off-by: withchao <993506633@qq.com> Signed-off-by: Gordon <46924906+FGadvancer@users.noreply.github.com> Signed-off-by: github-actions[bot] <41898282+github-actions[bot]@users.noreply.github.com> Co-authored-by: withchao <993506633@qq.com> Co-authored-by: Xinwei Xiong <3293172751NSS@gmail.com> Co-authored-by: FGadvancer <FGadvancer@users.noreply.github.com> Co-authored-by: withchao <withchao@users.noreply.github.com>
		
			
				
	
	
		
			277 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
			
		
		
	
	
			277 lines
		
	
	
		
			12 KiB
		
	
	
	
		
			Go
		
	
	
	
	
	
| // Copyright © 2023 OpenIM. All rights reserved.
 | |
| //
 | |
| // Licensed under the Apache License, Version 2.0 (the "License");
 | |
| // you may not use this file except in compliance with the License.
 | |
| // You may obtain a copy of the License at
 | |
| //
 | |
| //     http://www.apache.org/licenses/LICENSE-2.0
 | |
| //
 | |
| // Unless required by applicable law or agreed to in writing, software
 | |
| // distributed under the License is distributed on an "AS IS" BASIS,
 | |
| // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
 | |
| // See the License for the specific language governing permissions and
 | |
| // limitations under the License.
 | |
| 
 | |
| package rpcclient
 | |
| 
 | |
| import (
 | |
| 	"context"
 | |
| 	"encoding/json"
 | |
| 
 | |
| 	"google.golang.org/grpc"
 | |
| 	"google.golang.org/protobuf/proto"
 | |
| 
 | |
| 	"github.com/OpenIMSDK/protocol/constant"
 | |
| 	"github.com/OpenIMSDK/protocol/msg"
 | |
| 	"github.com/OpenIMSDK/protocol/sdkws"
 | |
| 	"github.com/OpenIMSDK/tools/discoveryregistry"
 | |
| 	"github.com/OpenIMSDK/tools/log"
 | |
| 	"github.com/OpenIMSDK/tools/utils"
 | |
| 
 | |
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config"
 | |
| 	// "google.golang.org/protobuf/proto".
 | |
| )
 | |
| 
 | |
| func newContentTypeConf() map[int32]config.NotificationConf {
 | |
| 	return map[int32]config.NotificationConf{
 | |
| 		// group
 | |
| 		constant.GroupCreatedNotification:                 config.Config.Notification.GroupCreated,
 | |
| 		constant.GroupInfoSetNotification:                 config.Config.Notification.GroupInfoSet,
 | |
| 		constant.JoinGroupApplicationNotification:         config.Config.Notification.JoinGroupApplication,
 | |
| 		constant.MemberQuitNotification:                   config.Config.Notification.MemberQuit,
 | |
| 		constant.GroupApplicationAcceptedNotification:     config.Config.Notification.GroupApplicationAccepted,
 | |
| 		constant.GroupApplicationRejectedNotification:     config.Config.Notification.GroupApplicationRejected,
 | |
| 		constant.GroupOwnerTransferredNotification:        config.Config.Notification.GroupOwnerTransferred,
 | |
| 		constant.MemberKickedNotification:                 config.Config.Notification.MemberKicked,
 | |
| 		constant.MemberInvitedNotification:                config.Config.Notification.MemberInvited,
 | |
| 		constant.MemberEnterNotification:                  config.Config.Notification.MemberEnter,
 | |
| 		constant.GroupDismissedNotification:               config.Config.Notification.GroupDismissed,
 | |
| 		constant.GroupMutedNotification:                   config.Config.Notification.GroupMuted,
 | |
| 		constant.GroupCancelMutedNotification:             config.Config.Notification.GroupCancelMuted,
 | |
| 		constant.GroupMemberMutedNotification:             config.Config.Notification.GroupMemberMuted,
 | |
| 		constant.GroupMemberCancelMutedNotification:       config.Config.Notification.GroupMemberCancelMuted,
 | |
| 		constant.GroupMemberInfoSetNotification:           config.Config.Notification.GroupMemberInfoSet,
 | |
| 		constant.GroupMemberSetToAdminNotification:        config.Config.Notification.GroupMemberSetToAdmin,
 | |
| 		constant.GroupMemberSetToOrdinaryUserNotification: config.Config.Notification.GroupMemberSetToOrdinary,
 | |
| 		constant.GroupInfoSetAnnouncementNotification:     config.Config.Notification.GroupInfoSetAnnouncement,
 | |
| 		constant.GroupInfoSetNameNotification:             config.Config.Notification.GroupInfoSetName,
 | |
| 		// user
 | |
| 		constant.UserInfoUpdatedNotification:  config.Config.Notification.UserInfoUpdated,
 | |
| 		constant.UserStatusChangeNotification: config.Config.Notification.UserStatusChanged,
 | |
| 		// friend
 | |
| 		constant.FriendApplicationNotification:         config.Config.Notification.FriendApplicationAdded,
 | |
| 		constant.FriendApplicationApprovedNotification: config.Config.Notification.FriendApplicationApproved,
 | |
| 		constant.FriendApplicationRejectedNotification: config.Config.Notification.FriendApplicationRejected,
 | |
| 		constant.FriendAddedNotification:               config.Config.Notification.FriendAdded,
 | |
| 		constant.FriendDeletedNotification:             config.Config.Notification.FriendDeleted,
 | |
| 		constant.FriendRemarkSetNotification:           config.Config.Notification.FriendRemarkSet,
 | |
| 		constant.BlackAddedNotification:                config.Config.Notification.BlackAdded,
 | |
| 		constant.BlackDeletedNotification:              config.Config.Notification.BlackDeleted,
 | |
| 		constant.FriendInfoUpdatedNotification:         config.Config.Notification.FriendInfoUpdated,
 | |
| 		// conversation
 | |
| 		constant.ConversationChangeNotification:      config.Config.Notification.ConversationChanged,
 | |
| 		constant.ConversationUnreadNotification:      config.Config.Notification.ConversationChanged,
 | |
| 		constant.ConversationPrivateChatNotification: config.Config.Notification.ConversationSetPrivate,
 | |
| 		// msg
 | |
| 		constant.MsgRevokeNotification:  {IsSendMsg: false, ReliabilityLevel: constant.ReliableNotificationNoMsg},
 | |
| 		constant.HasReadReceipt:         {IsSendMsg: false, ReliabilityLevel: constant.ReliableNotificationNoMsg},
 | |
| 		constant.DeleteMsgsNotification: {IsSendMsg: false, ReliabilityLevel: constant.ReliableNotificationNoMsg},
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func newSessionTypeConf() map[int32]int32 {
 | |
| 	return map[int32]int32{
 | |
| 		// group
 | |
| 		constant.GroupCreatedNotification:                 constant.SuperGroupChatType,
 | |
| 		constant.GroupInfoSetNotification:                 constant.SuperGroupChatType,
 | |
| 		constant.JoinGroupApplicationNotification:         constant.SingleChatType,
 | |
| 		constant.MemberQuitNotification:                   constant.SuperGroupChatType,
 | |
| 		constant.GroupApplicationAcceptedNotification:     constant.SingleChatType,
 | |
| 		constant.GroupApplicationRejectedNotification:     constant.SingleChatType,
 | |
| 		constant.GroupOwnerTransferredNotification:        constant.SuperGroupChatType,
 | |
| 		constant.MemberKickedNotification:                 constant.SuperGroupChatType,
 | |
| 		constant.MemberInvitedNotification:                constant.SuperGroupChatType,
 | |
| 		constant.MemberEnterNotification:                  constant.SuperGroupChatType,
 | |
| 		constant.GroupDismissedNotification:               constant.SuperGroupChatType,
 | |
| 		constant.GroupMutedNotification:                   constant.SuperGroupChatType,
 | |
| 		constant.GroupCancelMutedNotification:             constant.SuperGroupChatType,
 | |
| 		constant.GroupMemberMutedNotification:             constant.SuperGroupChatType,
 | |
| 		constant.GroupMemberCancelMutedNotification:       constant.SuperGroupChatType,
 | |
| 		constant.GroupMemberInfoSetNotification:           constant.SuperGroupChatType,
 | |
| 		constant.GroupMemberSetToAdminNotification:        constant.SuperGroupChatType,
 | |
| 		constant.GroupMemberSetToOrdinaryUserNotification: constant.SuperGroupChatType,
 | |
| 		constant.GroupInfoSetAnnouncementNotification:     constant.SuperGroupChatType,
 | |
| 		constant.GroupInfoSetNameNotification:             constant.SuperGroupChatType,
 | |
| 		// user
 | |
| 		constant.UserInfoUpdatedNotification:  constant.SingleChatType,
 | |
| 		constant.UserStatusChangeNotification: constant.SingleChatType,
 | |
| 		// friend
 | |
| 		constant.FriendApplicationNotification:         constant.SingleChatType,
 | |
| 		constant.FriendApplicationApprovedNotification: constant.SingleChatType,
 | |
| 		constant.FriendApplicationRejectedNotification: constant.SingleChatType,
 | |
| 		constant.FriendAddedNotification:               constant.SingleChatType,
 | |
| 		constant.FriendDeletedNotification:             constant.SingleChatType,
 | |
| 		constant.FriendRemarkSetNotification:           constant.SingleChatType,
 | |
| 		constant.BlackAddedNotification:                constant.SingleChatType,
 | |
| 		constant.BlackDeletedNotification:              constant.SingleChatType,
 | |
| 		constant.FriendInfoUpdatedNotification:         constant.SingleChatType,
 | |
| 		// conversation
 | |
| 		constant.ConversationChangeNotification:      constant.SingleChatType,
 | |
| 		constant.ConversationUnreadNotification:      constant.SingleChatType,
 | |
| 		constant.ConversationPrivateChatNotification: constant.SingleChatType,
 | |
| 		// delete
 | |
| 		constant.DeleteMsgsNotification: constant.SingleChatType,
 | |
| 	}
 | |
| }
 | |
| 
 | |
| type Message struct {
 | |
| 	conn   grpc.ClientConnInterface
 | |
| 	Client msg.MsgClient
 | |
| 	discov discoveryregistry.SvcDiscoveryRegistry
 | |
| }
 | |
| 
 | |
| func NewMessage(discov discoveryregistry.SvcDiscoveryRegistry) *Message {
 | |
| 	conn, err := discov.GetConn(context.Background(), config.Config.RpcRegisterName.OpenImMsgName)
 | |
| 	if err != nil {
 | |
| 		panic(err)
 | |
| 	}
 | |
| 	client := msg.NewMsgClient(conn)
 | |
| 	return &Message{discov: discov, conn: conn, Client: client}
 | |
| }
 | |
| 
 | |
| type MessageRpcClient Message
 | |
| 
 | |
| func NewMessageRpcClient(discov discoveryregistry.SvcDiscoveryRegistry) MessageRpcClient {
 | |
| 	return MessageRpcClient(*NewMessage(discov))
 | |
| }
 | |
| 
 | |
| func (m *MessageRpcClient) SendMsg(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error) {
 | |
| 	resp, err := m.Client.SendMsg(ctx, req)
 | |
| 	return resp, err
 | |
| }
 | |
| 
 | |
| func (m *MessageRpcClient) GetMaxSeq(ctx context.Context, req *sdkws.GetMaxSeqReq) (*sdkws.GetMaxSeqResp, error) {
 | |
| 	resp, err := m.Client.GetMaxSeq(ctx, req)
 | |
| 	return resp, err
 | |
| }
 | |
| 
 | |
| func (m *MessageRpcClient) PullMessageBySeqList(ctx context.Context, req *sdkws.PullMessageBySeqsReq) (*sdkws.PullMessageBySeqsResp, error) {
 | |
| 	resp, err := m.Client.PullMessageBySeqs(ctx, req)
 | |
| 	return resp, err
 | |
| }
 | |
| 
 | |
| func (m *MessageRpcClient) GetConversationMaxSeq(ctx context.Context, conversationID string) (int64, error) {
 | |
| 	resp, err := m.Client.GetConversationMaxSeq(ctx, &msg.GetConversationMaxSeqReq{ConversationID: conversationID})
 | |
| 	if err != nil {
 | |
| 		return 0, err
 | |
| 	}
 | |
| 	return resp.MaxSeq, nil
 | |
| }
 | |
| 
 | |
| type NotificationSender struct {
 | |
| 	contentTypeConf map[int32]config.NotificationConf
 | |
| 	sessionTypeConf map[int32]int32
 | |
| 	sendMsg         func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error)
 | |
| 	getUserInfo     func(ctx context.Context, userID string) (*sdkws.UserInfo, error)
 | |
| }
 | |
| 
 | |
| type NotificationSenderOptions func(*NotificationSender)
 | |
| 
 | |
| func WithLocalSendMsg(sendMsg func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error)) NotificationSenderOptions {
 | |
| 	return func(s *NotificationSender) {
 | |
| 		s.sendMsg = sendMsg
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func WithRpcClient(msgRpcClient *MessageRpcClient) NotificationSenderOptions {
 | |
| 	return func(s *NotificationSender) {
 | |
| 		s.sendMsg = msgRpcClient.SendMsg
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func WithUserRpcClient(userRpcClient *UserRpcClient) NotificationSenderOptions {
 | |
| 	return func(s *NotificationSender) {
 | |
| 		s.getUserInfo = userRpcClient.GetUserInfo
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func NewNotificationSender(opts ...NotificationSenderOptions) *NotificationSender {
 | |
| 	notificationSender := &NotificationSender{contentTypeConf: newContentTypeConf(), sessionTypeConf: newSessionTypeConf()}
 | |
| 	for _, opt := range opts {
 | |
| 		opt(notificationSender)
 | |
| 	}
 | |
| 	return notificationSender
 | |
| }
 | |
| 
 | |
| type notificationOpt struct {
 | |
| 	WithRpcGetUsername bool
 | |
| }
 | |
| 
 | |
| type NotificationOptions func(*notificationOpt)
 | |
| 
 | |
| func WithRpcGetUserName() NotificationOptions {
 | |
| 	return func(opt *notificationOpt) {
 | |
| 		opt.WithRpcGetUsername = true
 | |
| 	}
 | |
| }
 | |
| 
 | |
| func (s *NotificationSender) NotificationWithSesstionType(ctx context.Context, sendID, recvID string, contentType, sesstionType int32, m proto.Message, opts ...NotificationOptions) (err error) {
 | |
| 	n := sdkws.NotificationElem{Detail: utils.StructToJsonString(m)}
 | |
| 	content, err := json.Marshal(&n)
 | |
| 	if err != nil {
 | |
| 		log.ZError(ctx, "MsgClient Notification json.Marshal failed", err, "sendID", sendID, "recvID", recvID, "contentType", contentType, "msg", m)
 | |
| 		return err
 | |
| 	}
 | |
| 	notificationOpt := ¬ificationOpt{}
 | |
| 	for _, opt := range opts {
 | |
| 		opt(notificationOpt)
 | |
| 	}
 | |
| 	var req msg.SendMsgReq
 | |
| 	var msg sdkws.MsgData
 | |
| 	var userInfo *sdkws.UserInfo
 | |
| 	if notificationOpt.WithRpcGetUsername && s.getUserInfo != nil {
 | |
| 		userInfo, err = s.getUserInfo(ctx, sendID)
 | |
| 		if err != nil {
 | |
| 			log.ZWarn(ctx, "getUserInfo failed", err, "sendID", sendID)
 | |
| 		} else {
 | |
| 			msg.SenderNickname = userInfo.Nickname
 | |
| 			msg.SenderFaceURL = userInfo.FaceURL
 | |
| 		}
 | |
| 	}
 | |
| 	var offlineInfo sdkws.OfflinePushInfo
 | |
| 	var title, desc, ex string
 | |
| 	msg.SendID = sendID
 | |
| 	msg.RecvID = recvID
 | |
| 	msg.Content = content
 | |
| 	msg.MsgFrom = constant.SysMsgType
 | |
| 	msg.ContentType = contentType
 | |
| 	msg.SessionType = sesstionType
 | |
| 	if msg.SessionType == constant.SuperGroupChatType {
 | |
| 		msg.GroupID = recvID
 | |
| 	}
 | |
| 	msg.CreateTime = utils.GetCurrentTimestampByMill()
 | |
| 	msg.ClientMsgID = utils.GetMsgID(sendID)
 | |
| 	optionsConfig := s.contentTypeConf[contentType]
 | |
| 	if sendID == recvID && contentType == constant.HasReadReceipt {
 | |
| 		optionsConfig.ReliabilityLevel = constant.UnreliableNotification
 | |
| 	}
 | |
| 	options := config.GetOptionsByNotification(optionsConfig)
 | |
| 	msg.Options = options
 | |
| 	offlineInfo.Title = title
 | |
| 	offlineInfo.Desc = desc
 | |
| 	offlineInfo.Ex = ex
 | |
| 	msg.OfflinePushInfo = &offlineInfo
 | |
| 	req.MsgData = &msg
 | |
| 	_, err = s.sendMsg(ctx, &req)
 | |
| 	if err == nil {
 | |
| 		log.ZDebug(ctx, "MsgClient Notification SendMsg success", "req", &req)
 | |
| 	} else {
 | |
| 		log.ZError(ctx, "MsgClient Notification SendMsg failed", err, "req", &req)
 | |
| 	}
 | |
| 	return err
 | |
| }
 | |
| 
 | |
| func (s *NotificationSender) Notification(ctx context.Context, sendID, recvID string, contentType int32, m proto.Message, opts ...NotificationOptions) error {
 | |
| 	return s.NotificationWithSesstionType(ctx, sendID, recvID, contentType, s.sessionTypeConf[contentType], m, opts...)
 | |
| }
 |