mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 13:12:12 +08:00 
			
		
		
		
	feat: add a field to specify whether to send a notification message w… (#3163)
* feat: add a field to specify whether to send a notification message when creating a group. * feat: add a field to specify whether to send a notification message when creating a group. --------- Co-authored-by: Monet Lee <monet_lee@163.com>
This commit is contained in:
		
							parent
							
								
									f242066f30
								
							
						
					
					
						commit
						cc788d8aea
					
				
							
								
								
									
										4
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.mod
									
									
									
									
									
								
							| @ -12,8 +12,8 @@ require ( | ||||
| 	github.com/gorilla/websocket v1.5.1 | ||||
| 	github.com/grpc-ecosystem/go-grpc-prometheus v1.2.0 | ||||
| 	github.com/mitchellh/mapstructure v1.5.0 | ||||
| 	github.com/openimsdk/protocol v0.0.72-alpha.71 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.72 | ||||
| 	github.com/openimsdk/protocol v0.0.72-alpha.77 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.74 | ||||
| 	github.com/pkg/errors v0.9.1 // indirect | ||||
| 	github.com/prometheus/client_golang v1.18.0 | ||||
| 	github.com/stretchr/testify v1.9.0 | ||||
|  | ||||
							
								
								
									
										12
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								go.sum
									
									
									
									
									
								
							| @ -317,12 +317,12 @@ github.com/onsi/ginkgo v1.16.5 h1:8xi0RTUf59SOSfEtZMvwTvXYMzG4gV23XVHOZiXNtnE= | ||||
| github.com/onsi/ginkgo v1.16.5/go.mod h1:+E8gABHa3K6zRBolWtd+ROzc/U5bkGt0FwiG042wbpU= | ||||
| github.com/onsi/gomega v1.25.0 h1:Vw7br2PCDYijJHSfBOWhov+8cAnUf8MfMaIOV323l6Y= | ||||
| github.com/onsi/gomega v1.25.0/go.mod h1:r+zV744Re+DiYCIPRlYOTxn0YkOLcAnW8k1xXdMPGhM= | ||||
| github.com/openimsdk/gomake v0.0.14-alpha.5 h1:VY9c5x515lTfmdhhPjMvR3BBRrRquAUCFsz7t7vbv7Y= | ||||
| github.com/openimsdk/gomake v0.0.14-alpha.5/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.71 h1:R3utzOlqepaJWTAmnfJi4ccUM/XIoFasSyjQMOipM70= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.71/go.mod h1:WF7EuE55vQvpyUAzDXcqg+B+446xQyEba0X35lTINmw= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.72 h1:d/vaZjIfvrNp3EeRJEIiamBO7HiPx6CP4wiuq8NpfzY= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.72/go.mod h1:B+oqV0zdewN7OiEHYJm+hW+8/Te7B8tHHgD8rK5ZLZk= | ||||
| github.com/openimsdk/gomake v0.0.15-alpha.2 h1:5Q8yl8ezy2yx+q8/ucU/t4kJnDfCzNOrkXcDACCqtyM= | ||||
| github.com/openimsdk/gomake v0.0.15-alpha.2/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.77 h1:ka7TeOpNKKqYTz8aWR8nZnz2rnzgsO9mw6xOQcVXwbE= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.77/go.mod h1:WF7EuE55vQvpyUAzDXcqg+B+446xQyEba0X35lTINmw= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.74 h1:yh10SiMiivMEjicEQg+QAsH4pvaO+4noMPdlw+ew0Kc= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.74/go.mod h1:n2poR3asX1e1XZce4O+MOWAp+X02QJRFvhcLCXZdzRo= | ||||
| github.com/pelletier/go-toml/v2 v2.2.2 h1:aYUidT7k73Pcl9nb2gScu7NSrKCSHIDE89b3+6Wq+LM= | ||||
| github.com/pelletier/go-toml/v2 v2.2.2/go.mod h1:1t835xjRzz80PqgE6HHgN2JOsmgYu/h4qDAS4n929Rs= | ||||
| github.com/pierrec/lz4/v4 v4.1.21 h1:yOVMLb6qSIDP67pl/5F7RepeKYu/VmTyEXvuMI5d9mQ= | ||||
|  | ||||
| @ -281,7 +281,7 @@ func (m *MessageApi) SendBusinessNotification(c *gin.Context) { | ||||
| 				IsSendMsg:        false, | ||||
| 				ReliabilityLevel: 1, | ||||
| 				UnreadCount:      false, | ||||
| 			}), | ||||
| 			}, nil), | ||||
| 		}, | ||||
| 	} | ||||
| 	respPb, err := m.Client.SendMsg(c, &sendMsgReq) | ||||
|  | ||||
| @ -16,6 +16,7 @@ package conversation | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 	"github.com/openimsdk/protocol/msg" | ||||
| 
 | ||||
| @ -26,11 +27,11 @@ import ( | ||||
| ) | ||||
| 
 | ||||
| type ConversationNotificationSender struct { | ||||
| 	*rpcclient.NotificationSender | ||||
| 	*notification.NotificationSender | ||||
| } | ||||
| 
 | ||||
| func NewConversationNotificationSender(conf *config.Notification, msgClient *rpcli.MsgClient) *ConversationNotificationSender { | ||||
| 	return &ConversationNotificationSender{rpcclient.NewNotificationSender(conf, rpcclient.WithRpcClient(func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error) { | ||||
| 	return &ConversationNotificationSender{notification.NewNotificationSender(conf, notification.WithRpcClient(func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error) { | ||||
| 		return msgClient.SendMsg(ctx, req) | ||||
| 	}))} | ||||
| } | ||||
|  | ||||
| @ -24,6 +24,13 @@ import ( | ||||
| 	"strings" | ||||
| 	"time" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/dbbuild" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 
 | ||||
| 	"google.golang.org/grpc" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/authverify" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/callbackstruct" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/common" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database/mgo" | ||||
| @ -52,7 +59,6 @@ import ( | ||||
| 	"github.com/openimsdk/tools/mw/specialerror" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"github.com/openimsdk/tools/utils/encrypt" | ||||
| 	"google.golang.org/grpc" | ||||
| ) | ||||
| 
 | ||||
| type groupServer struct { | ||||
| @ -289,7 +295,7 @@ func (g *groupServer) CreateGroup(ctx context.Context, req *pbgroup.CreateGroupR | ||||
| 			break | ||||
| 		} | ||||
| 	} | ||||
| 	g.notification.GroupCreatedNotification(ctx, tips) | ||||
| 	g.notification.GroupCreatedNotification(ctx, tips, req.SendNotification) | ||||
| 
 | ||||
| 	if req.GroupInfo.Notification != "" { | ||||
| 		g.notification.GroupInfoSetAnnouncementNotification(ctx, &sdkws.GroupInfoSetAnnouncementTips{ | ||||
| @ -452,7 +458,7 @@ func (g *groupServer) InviteUserToGroup(ctx context.Context, req *pbgroup.Invite | ||||
| 		return nil, err | ||||
| 	} | ||||
| 
 | ||||
| 	if err = g.notification.GroupApplicationAgreeMemberEnterNotification(ctx, req.GroupID, opUserID, req.InvitedUserIDs...); err != nil { | ||||
| 	if err = g.notification.GroupApplicationAgreeMemberEnterNotification(ctx, req.GroupID, req.SendNotification, opUserID, req.InvitedUserIDs...); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| 	return &pbgroup.InviteUserToGroupResp{}, nil | ||||
| @ -618,7 +624,7 @@ func (g *groupServer) KickGroupMember(ctx context.Context, req *pbgroup.KickGrou | ||||
| 	for _, userID := range req.KickedUserIDs { | ||||
| 		tips.KickedUserList = append(tips.KickedUserList, convert.Db2PbGroupMember(memberMap[userID])) | ||||
| 	} | ||||
| 	g.notification.MemberKickedNotification(ctx, tips) | ||||
| 	g.notification.MemberKickedNotification(ctx, tips, req.SendNotification) | ||||
| 	if err := g.deleteMemberAndSetConversationSeq(ctx, req.GroupID, req.KickedUserIDs); err != nil { | ||||
| 		return nil, err | ||||
| 	} | ||||
| @ -827,7 +833,7 @@ func (g *groupServer) GroupApplicationResponse(ctx context.Context, req *pbgroup | ||||
| 		if member == nil { | ||||
| 			log.ZDebug(ctx, "GroupApplicationResponse", "member is nil") | ||||
| 		} else { | ||||
| 			if err = g.notification.GroupApplicationAgreeMemberEnterNotification(ctx, req.GroupID, groupRequest.InviterUserID, req.FromUserID); err != nil { | ||||
| 			if err = g.notification.GroupApplicationAgreeMemberEnterNotification(ctx, req.GroupID, nil, groupRequest.InviterUserID, req.FromUserID); err != nil { | ||||
| 				return nil, err | ||||
| 			} | ||||
| 		} | ||||
| @ -1373,7 +1379,7 @@ func (g *groupServer) DismissGroup(ctx context.Context, req *pbgroup.DismissGrou | ||||
| 		if mcontext.GetOpUserID(ctx) == owner.UserID { | ||||
| 			tips.OpUser = g.groupMemberDB2PB(owner, 0) | ||||
| 		} | ||||
| 		g.notification.GroupDismissedNotification(ctx, tips) | ||||
| 		g.notification.GroupDismissedNotification(ctx, tips, req.SendNotification) | ||||
| 	} | ||||
| 	membersID, err := g.db.FindGroupMemberUserID(ctx, group.GroupID) | ||||
| 	if err != nil { | ||||
|  | ||||
| @ -22,6 +22,8 @@ import ( | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 
 | ||||
| 	"go.mongodb.org/mongo-driver/mongo" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/authverify" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/convert" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/servererrs" | ||||
| @ -41,7 +43,6 @@ import ( | ||||
| 	"github.com/openimsdk/tools/mcontext" | ||||
| 	"github.com/openimsdk/tools/utils/datautil" | ||||
| 	"github.com/openimsdk/tools/utils/stringutil" | ||||
| 	"go.mongodb.org/mongo-driver/mongo" | ||||
| ) | ||||
| 
 | ||||
| // GroupApplicationReceiver | ||||
| @ -52,11 +53,11 @@ const ( | ||||
| 
 | ||||
| func NewNotificationSender(db controller.GroupDatabase, config *Config, userClient *rpcli.UserClient, msgClient *rpcli.MsgClient, conversationClient *rpcli.ConversationClient) *NotificationSender { | ||||
| 	return &NotificationSender{ | ||||
| 		NotificationSender: rpcclient.NewNotificationSender(&config.NotificationConfig, | ||||
| 			rpcclient.WithRpcClient(func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error) { | ||||
| 		NotificationSender: notification.NewNotificationSender(&config.NotificationConfig, | ||||
| 			notification.WithRpcClient(func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error) { | ||||
| 				return msgClient.SendMsg(ctx, req) | ||||
| 			}), | ||||
| 			rpcclient.WithUserRpcClient(userClient.GetUserInfo), | ||||
| 			notification.WithUserRpcClient(userClient.GetUserInfo), | ||||
| 		), | ||||
| 		getUsersInfo: func(ctx context.Context, userIDs []string) ([]common_user.CommonUser, error) { | ||||
| 			users, err := userClient.GetUsersInfo(ctx, userIDs) | ||||
| @ -73,7 +74,7 @@ func NewNotificationSender(db controller.GroupDatabase, config *Config, userClie | ||||
| } | ||||
| 
 | ||||
| type NotificationSender struct { | ||||
| 	*rpcclient.NotificationSender | ||||
| 	*notification.NotificationSender | ||||
| 	getUsersInfo       func(ctx context.Context, userIDs []string) ([]common_user.CommonUser, error) | ||||
| 	db                 controller.GroupDatabase | ||||
| 	config             *Config | ||||
| @ -307,7 +308,7 @@ func (g *NotificationSender) setSortVersion(ctx context.Context, version *uint64 | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) GroupCreatedNotification(ctx context.Context, tips *sdkws.GroupCreatedTips) { | ||||
| func (g *NotificationSender) GroupCreatedNotification(ctx context.Context, tips *sdkws.GroupCreatedTips, sendNotification *bool) { | ||||
| 	var err error | ||||
| 	defer func() { | ||||
| 		if err != nil { | ||||
| @ -318,7 +319,7 @@ func (g *NotificationSender) GroupCreatedNotification(ctx context.Context, tips | ||||
| 		return | ||||
| 	} | ||||
| 	g.setVersion(ctx, &tips.GroupMemberVersion, &tips.GroupMemberVersionID, database.GroupMemberVersionName, tips.Group.GroupID) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.GroupCreatedNotification, tips) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.GroupCreatedNotification, tips, notification.WithSendNotification(sendNotification)) | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) GroupInfoSetNotification(ctx context.Context, tips *sdkws.GroupInfoSetTips) { | ||||
| @ -332,7 +333,7 @@ func (g *NotificationSender) GroupInfoSetNotification(ctx context.Context, tips | ||||
| 		return | ||||
| 	} | ||||
| 	g.setVersion(ctx, &tips.GroupMemberVersion, &tips.GroupMemberVersionID, database.GroupMemberVersionName, tips.Group.GroupID) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.GroupInfoSetNotification, tips, rpcclient.WithRpcGetUserName()) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.GroupInfoSetNotification, tips, notification.WithRpcGetUserName()) | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) GroupInfoSetNameNotification(ctx context.Context, tips *sdkws.GroupInfoSetNameTips) { | ||||
| @ -360,7 +361,7 @@ func (g *NotificationSender) GroupInfoSetAnnouncementNotification(ctx context.Co | ||||
| 		return | ||||
| 	} | ||||
| 	g.setVersion(ctx, &tips.GroupMemberVersion, &tips.GroupMemberVersionID, database.GroupMemberVersionName, tips.Group.GroupID) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.GroupInfoSetAnnouncementNotification, tips, rpcclient.WithRpcGetUserName()) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.GroupInfoSetAnnouncementNotification, tips, notification.WithRpcGetUserName()) | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) JoinGroupApplicationNotification(ctx context.Context, req *pbgroup.JoinGroupReq) { | ||||
| @ -505,7 +506,7 @@ func (g *NotificationSender) GroupOwnerTransferredNotification(ctx context.Conte | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), group.GroupID, constant.GroupOwnerTransferredNotification, tips) | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) MemberKickedNotification(ctx context.Context, tips *sdkws.MemberKickedTips) { | ||||
| func (g *NotificationSender) MemberKickedNotification(ctx context.Context, tips *sdkws.MemberKickedTips, sendNotification *bool) { | ||||
| 	var err error | ||||
| 	defer func() { | ||||
| 		if err != nil { | ||||
| @ -516,10 +517,10 @@ func (g *NotificationSender) MemberKickedNotification(ctx context.Context, tips | ||||
| 		return | ||||
| 	} | ||||
| 	g.setVersion(ctx, &tips.GroupMemberVersion, &tips.GroupMemberVersionID, database.GroupMemberVersionName, tips.Group.GroupID) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.MemberKickedNotification, tips) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.MemberKickedNotification, tips, notification.WithSendNotification(sendNotification)) | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) GroupApplicationAgreeMemberEnterNotification(ctx context.Context, groupID string, invitedOpUserID string, entrantUserID ...string) error { | ||||
| func (g *NotificationSender) GroupApplicationAgreeMemberEnterNotification(ctx context.Context, groupID string, sendNotification *bool, invitedOpUserID string, entrantUserID ...string) error { | ||||
| 	var err error | ||||
| 	defer func() { | ||||
| 		if err != nil { | ||||
| @ -569,7 +570,7 @@ func (g *NotificationSender) GroupApplicationAgreeMemberEnterNotification(ctx co | ||||
| 		} | ||||
| 	} | ||||
| 	g.setVersion(ctx, &tips.GroupMemberVersion, &tips.GroupMemberVersionID, database.GroupMemberVersionName, tips.Group.GroupID) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), group.GroupID, constant.MemberInvitedNotification, tips) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), group.GroupID, constant.MemberInvitedNotification, tips, notification.WithSendNotification(sendNotification)) | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| @ -614,7 +615,7 @@ func (g *NotificationSender) MemberEnterNotification(ctx context.Context, groupI | ||||
| 	return nil | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) GroupDismissedNotification(ctx context.Context, tips *sdkws.GroupDismissedTips) { | ||||
| func (g *NotificationSender) GroupDismissedNotification(ctx context.Context, tips *sdkws.GroupDismissedTips, sendNotification *bool) { | ||||
| 	var err error | ||||
| 	defer func() { | ||||
| 		if err != nil { | ||||
| @ -624,7 +625,7 @@ func (g *NotificationSender) GroupDismissedNotification(ctx context.Context, tip | ||||
| 	if err = g.fillOpUser(ctx, &tips.OpUser, tips.Group.GroupID); err != nil { | ||||
| 		return | ||||
| 	} | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.GroupDismissedNotification, tips) | ||||
| 	g.Notification(ctx, mcontext.GetOpUserID(ctx), tips.Group.GroupID, constant.GroupDismissedNotification, tips, notification.WithSendNotification(sendNotification)) | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) GroupMemberMutedNotification(ctx context.Context, groupID, groupMemberUserID string, mutedSeconds uint32) { | ||||
|  | ||||
| @ -23,11 +23,11 @@ import ( | ||||
| ) | ||||
| 
 | ||||
| type MsgNotificationSender struct { | ||||
| 	*rpcclient.NotificationSender | ||||
| 	*notification.NotificationSender | ||||
| } | ||||
| 
 | ||||
| func NewMsgNotificationSender(config *Config, opts ...rpcclient.NotificationSenderOptions) *MsgNotificationSender { | ||||
| 	return &MsgNotificationSender{rpcclient.NewNotificationSender(&config.NotificationConfig, opts...)} | ||||
| func NewMsgNotificationSender(config *Config, opts ...notification.NotificationSenderOptions) *MsgNotificationSender { | ||||
| 	return &MsgNotificationSender{notification.NewNotificationSender(&config.NotificationConfig, opts...)} | ||||
| } | ||||
| 
 | ||||
| func (m *MsgNotificationSender) UserDeleteMsgsNotification(ctx context.Context, userID, conversationID string, seqs []int64) { | ||||
|  | ||||
| @ -18,6 +18,8 @@ import ( | ||||
| 	"context" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 
 | ||||
| 	"google.golang.org/grpc" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/config" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/cache/redis" | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/common/storage/database/mgo" | ||||
| @ -33,7 +35,6 @@ import ( | ||||
| 	"github.com/openimsdk/protocol/conversation" | ||||
| 	"github.com/openimsdk/protocol/msg" | ||||
| 	"github.com/openimsdk/tools/discovery" | ||||
| 	"google.golang.org/grpc" | ||||
| ) | ||||
| 
 | ||||
| type MessageInterceptorFunc func(ctx context.Context, globalConfig *Config, req *msg.SendMsgReq) (*sdkws.MsgData, error) | ||||
| @ -63,7 +64,7 @@ type msgServer struct { | ||||
| 	GroupLocalCache        *rpccache.GroupLocalCache        // Local cache for group data. | ||||
| 	ConversationLocalCache *rpccache.ConversationLocalCache // Local cache for conversation data. | ||||
| 	Handlers               MessageInterceptorChain          // Chain of handlers for processing messages. | ||||
| 	notificationSender     *rpcclient.NotificationSender    // RPC client for sending notifications. | ||||
| 	notificationSender     *notification.NotificationSender // RPC client for sending notifications. | ||||
| 	msgNotificationSender  *MsgNotificationSender           // RPC client for sending msg notifications. | ||||
| 	config                 *Config                          // Global configuration settings. | ||||
| 	webhookClient          *webhook.Client | ||||
| @ -132,8 +133,8 @@ func Start(ctx context.Context, config *Config, client discovery.SvcDiscoveryReg | ||||
| 		conversationClient:     conversationClient, | ||||
| 	} | ||||
| 
 | ||||
| 	s.notificationSender = rpcclient.NewNotificationSender(&config.NotificationConfig, rpcclient.WithLocalSendMsg(s.SendMsg)) | ||||
| 	s.msgNotificationSender = NewMsgNotificationSender(config, rpcclient.WithLocalSendMsg(s.SendMsg)) | ||||
| 	s.notificationSender = notification.NewNotificationSender(&config.NotificationConfig, notification.WithLocalSendMsg(s.SendMsg)) | ||||
| 	s.msgNotificationSender = NewMsgNotificationSender(config, notification.WithLocalSendMsg(s.SendMsg)) | ||||
| 
 | ||||
| 	msg.RegisterMsgServer(server, s) | ||||
| 
 | ||||
|  | ||||
| @ -16,6 +16,7 @@ package relation | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 	"github.com/openimsdk/protocol/msg" | ||||
| 
 | ||||
| @ -36,7 +37,7 @@ import ( | ||||
| ) | ||||
| 
 | ||||
| type FriendNotificationSender struct { | ||||
| 	*rpcclient.NotificationSender | ||||
| 	*notification.NotificationSender | ||||
| 	// Target not found err | ||||
| 	getUsersInfo func(ctx context.Context, userIDs []string) ([]common_user.CommonUser, error) | ||||
| 	// db controller | ||||
| @ -89,7 +90,7 @@ func WithRpcFunc( | ||||
| 
 | ||||
| func NewFriendNotificationSender(conf *config.Notification, msgClient *rpcli.MsgClient, opts ...friendNotificationSenderOptions) *FriendNotificationSender { | ||||
| 	f := &FriendNotificationSender{ | ||||
| 		NotificationSender: rpcclient.NewNotificationSender(conf, rpcclient.WithRpcClient(func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error) { | ||||
| 		NotificationSender: notification.NewNotificationSender(conf, notification.WithRpcClient(func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error) { | ||||
| 			return msgClient.SendMsg(ctx, req) | ||||
| 		})), | ||||
| 	} | ||||
|  | ||||
| @ -16,6 +16,7 @@ package user | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/rpcli" | ||||
| 	"github.com/openimsdk/protocol/msg" | ||||
| 
 | ||||
| @ -29,7 +30,7 @@ import ( | ||||
| ) | ||||
| 
 | ||||
| type UserNotificationSender struct { | ||||
| 	*rpcclient.NotificationSender | ||||
| 	*notification.NotificationSender | ||||
| 	getUsersInfo func(ctx context.Context, userIDs []string) ([]common_user.CommonUser, error) | ||||
| 	// db controller | ||||
| 	db controller.UserDatabase | ||||
| @ -63,7 +64,7 @@ func WithUserFunc( | ||||
| 
 | ||||
| func NewUserNotificationSender(config *Config, msgClient *rpcli.MsgClient, opts ...userNotificationSenderOptions) *UserNotificationSender { | ||||
| 	f := &UserNotificationSender{ | ||||
| 		NotificationSender: rpcclient.NewNotificationSender(&config.NotificationConfig, rpcclient.WithRpcClient(func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error) { | ||||
| 		NotificationSender: notification.NewNotificationSender(&config.NotificationConfig, notification.WithRpcClient(func(ctx context.Context, req *msg.SendMsgReq) (*msg.SendMsgResp, error) { | ||||
| 			return msgClient.SendMsg(ctx, req) | ||||
| 		})), | ||||
| 	} | ||||
|  | ||||
| @ -18,11 +18,12 @@ import ( | ||||
| 	"os" | ||||
| 	"path/filepath" | ||||
| 
 | ||||
| 	"gopkg.in/yaml.v3" | ||||
| 
 | ||||
| 	"github.com/openimsdk/open-im-server/v3/pkg/msgprocessor" | ||||
| 	"github.com/openimsdk/protocol/constant" | ||||
| 	"github.com/openimsdk/tools/errs" | ||||
| 	"github.com/openimsdk/tools/field" | ||||
| 	"gopkg.in/yaml.v3" | ||||
| ) | ||||
| 
 | ||||
| const ( | ||||
| @ -58,10 +59,13 @@ func GetProjectRoot() (string, error) { | ||||
| 	return projectRoot, nil | ||||
| } | ||||
| 
 | ||||
| func GetOptionsByNotification(cfg NotificationConfig) msgprocessor.Options { | ||||
| func GetOptionsByNotification(cfg NotificationConfig, sendNotification *bool) msgprocessor.Options { | ||||
| 	opts := msgprocessor.NewOptions() | ||||
| 
 | ||||
| 	if cfg.UnreadCount { | ||||
| 	if sendNotification != nil { | ||||
| 		cfg.IsSendMsg = *sendNotification | ||||
| 	} | ||||
| 	if cfg.IsSendMsg { | ||||
| 		opts = msgprocessor.WithOptions(opts, msgprocessor.WithUnreadCount(true)) | ||||
| 	} | ||||
| 	if cfg.OfflinePush.Enable { | ||||
|  | ||||
| @ -12,7 +12,7 @@ | ||||
| // See the License for the specific language governing permissions and | ||||
| // limitations under the License. | ||||
| 
 | ||||
| package rpcclient | ||||
| package notification | ||||
| 
 | ||||
| import ( | ||||
| 	"context" | ||||
| @ -179,19 +179,24 @@ func NewNotificationSender(conf *config.Notification, opts ...NotificationSender | ||||
| } | ||||
| 
 | ||||
| type notificationOpt struct { | ||||
| 	WithRpcGetUsername bool | ||||
| 	RpcGetUsername   bool | ||||
| 	SendNotification *bool | ||||
| } | ||||
| 
 | ||||
| type NotificationOptions func(*notificationOpt) | ||||
| 
 | ||||
| func WithRpcGetUserName() NotificationOptions { | ||||
| 	return func(opt *notificationOpt) { | ||||
| 		opt.WithRpcGetUsername = true | ||||
| 		opt.RpcGetUsername = true | ||||
| 	} | ||||
| } | ||||
| func WithSendNotification(send *bool) NotificationOptions { | ||||
| 	return func(opt *notificationOpt) { | ||||
| 		opt.SendNotification = send | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
| func (s *NotificationSender) send(ctx context.Context, sendID, recvID string, contentType, sessionType int32, m proto.Message, opts ...NotificationOptions) { | ||||
| 	//ctx = mcontext.WithMustInfoCtx([]string{mcontext.GetOperationID(ctx), mcontext.GetOpUserID(ctx), mcontext.GetOpUserPlatform(ctx), mcontext.GetConnID(ctx)}) | ||||
| 	ctx = context.WithoutCancel(ctx) | ||||
| 	ctx, cancel := context.WithTimeout(ctx, time.Second*time.Duration(5)) | ||||
| 	defer cancel() | ||||
| @ -208,7 +213,7 @@ func (s *NotificationSender) send(ctx context.Context, sendID, recvID string, co | ||||
| 	var req msg.SendMsgReq | ||||
| 	var msg sdkws.MsgData | ||||
| 	var userInfo *sdkws.UserInfo | ||||
| 	if notificationOpt.WithRpcGetUsername && s.getUserInfo != nil { | ||||
| 	if notificationOpt.RpcGetUsername && s.getUserInfo != nil { | ||||
| 		userInfo, err = s.getUserInfo(ctx, sendID) | ||||
| 		if err != nil { | ||||
| 			log.ZWarn(ctx, "getUserInfo failed", err, "sendID", sendID) | ||||
| @ -233,7 +238,7 @@ func (s *NotificationSender) send(ctx context.Context, sendID, recvID string, co | ||||
| 	if sendID == recvID && contentType == constant.HasReadReceipt { | ||||
| 		optionsConfig.ReliabilityLevel = constant.UnreliableNotification | ||||
| 	} | ||||
| 	options := config.GetOptionsByNotification(optionsConfig) | ||||
| 	options := config.GetOptionsByNotification(optionsConfig, notificationOpt.SendNotification) | ||||
| 	s.SetOptionsByContentType(ctx, options, contentType) | ||||
| 	msg.Options = options | ||||
| 	// fill Notification OfflinePush by config | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user