mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-26 13:12:12 +08:00 
			
		
		
		
	fix: The message @ information will be set only for members in the group.
This commit is contained in:
		
							parent
							
								
									1110af98ef
								
							
						
					
					
						commit
						451266fc54
					
				
							
								
								
									
										2
									
								
								go.mod
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								go.mod
									
									
									
									
									
								
							| @ -13,7 +13,7 @@ require ( | ||||
| 	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.68 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.61 | ||||
| 	github.com/openimsdk/tools v0.0.50-alpha.62 | ||||
| 	github.com/pkg/errors v0.9.1 // indirect | ||||
| 	github.com/prometheus/client_golang v1.18.0 | ||||
| 	github.com/stretchr/testify v1.9.0 | ||||
|  | ||||
							
								
								
									
										4
									
								
								go.sum
									
									
									
									
									
								
							
							
						
						
									
										4
									
								
								go.sum
									
									
									
									
									
								
							| @ -349,8 +349,8 @@ github.com/openimsdk/gomake v0.0.15-alpha.2 h1:5Q8yl8ezy2yx+q8/ucU/t4kJnDfCzNOrk | ||||
| github.com/openimsdk/gomake v0.0.15-alpha.2/go.mod h1:PndCozNc2IsQIciyn9mvEblYWZwJmAI+06z94EY+csI= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.68 h1:Ekn6S9Ftt12Xs/p9kJ39RDr2gSwIczz+MmSHQE4lAek= | ||||
| github.com/openimsdk/protocol v0.0.72-alpha.68/go.mod h1:Iet+piS/jaS+kWWyj6EEr36mk4ISzIRYjoMSVA4dq2M= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.61 h1:zKEZwrj+fUVuyC6KR3kZp9zFaCCIFgoSbHO0r0mZ6h4= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.61/go.mod h1:JowL2jYr8tu4vcQe+5hJh4v3BtSx1T0CIS3pgU/Mw+U= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.62 h1:e/m1XL7+EXbkOoxr/En/612WcOPKOUHPBj0++gG6MuQ= | ||||
| github.com/openimsdk/tools v0.0.50-alpha.62/go.mod h1:JowL2jYr8tu4vcQe+5hJh4v3BtSx1T0CIS3pgU/Mw+U= | ||||
| 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= | ||||
|  | ||||
| @ -101,15 +101,15 @@ func (m *msgServer) setConversationAtInfo(nctx context.Context, msg *sdkws.MsgDa | ||||
| 		ConversationType: msg.SessionType, | ||||
| 		GroupID:          msg.GroupID, | ||||
| 	} | ||||
| 
 | ||||
| 	tagAll := datautil.Contain(constant.AtAllString, msg.AtUserIDList...) | ||||
| 	if tagAll { | ||||
| 	memberUserIDList, err := m.GroupLocalCache.GetGroupMemberIDs(ctx, msg.GroupID) | ||||
| 	if err != nil { | ||||
| 		log.ZWarn(ctx, "GetGroupMemberIDs", err) | ||||
| 		return | ||||
| 	} | ||||
| 
 | ||||
| 	tagAll := datautil.Contain(constant.AtAllString, msg.AtUserIDList...) | ||||
| 	if tagAll { | ||||
| 
 | ||||
| 		memberUserIDList = datautil.DeleteElems(memberUserIDList, msg.SendID) | ||||
| 
 | ||||
| 		atUserID = datautil.Single([]string{constant.AtAllString}, msg.AtUserIDList) | ||||
| @ -118,6 +118,9 @@ func (m *msgServer) setConversationAtInfo(nctx context.Context, msg *sdkws.MsgDa | ||||
| 			conversation.GroupAtType = &wrapperspb.Int32Value{Value: constant.AtAll} | ||||
| 		} else { // @Everyone and @other people | ||||
| 			conversation.GroupAtType = &wrapperspb.Int32Value{Value: constant.AtAllAtMe} | ||||
| 			atUserID = datautil.SliceIntersectFuncs(atUserID, memberUserIDList, func(a string) string { return a }, func(b string) string { | ||||
| 				return b | ||||
| 			}) | ||||
| 			if err := m.conversationClient.SetConversations(ctx, atUserID, conversation); err != nil { | ||||
| 				log.ZWarn(ctx, "SetConversations", err, "userID", atUserID, "conversation", conversation) | ||||
| 			} | ||||
| @ -131,10 +134,13 @@ func (m *msgServer) setConversationAtInfo(nctx context.Context, msg *sdkws.MsgDa | ||||
| 
 | ||||
| 		return | ||||
| 	} | ||||
| 	atUserID = datautil.SliceIntersectFuncs(msg.AtUserIDList, memberUserIDList, func(a string) string { return a }, func(b string) string { | ||||
| 		return b | ||||
| 	}) | ||||
| 	conversation.GroupAtType = &wrapperspb.Int32Value{Value: constant.AtMe} | ||||
| 
 | ||||
| 	if err := m.conversationClient.SetConversations(ctx, msg.AtUserIDList, conversation); err != nil { | ||||
| 		log.ZWarn(ctx, "SetConversations", err, msg.AtUserIDList, conversation) | ||||
| 	if err := m.conversationClient.SetConversations(ctx, atUserID, conversation); err != nil { | ||||
| 		log.ZWarn(ctx, "SetConversations", err, atUserID, conversation) | ||||
| 	} | ||||
| } | ||||
| 
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user