mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 20:52:11 +08:00 
			
		
		
		
	Merge pull request #3201 from openimsdk/cherry-pick-0541d0b
fix: solve uncorrect GroupMember enter group notification type. [Created by @mo3et from #3188]
This commit is contained in:
		
						commit
						b770f68919
					
				| @ -827,8 +827,14 @@ 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 { | ||||
| 				return nil, err | ||||
| 			if groupRequest.InviterUserID == "" { | ||||
| 				if err = g.notification.MemberEnterNotification(ctx, req.GroupID, req.FromUserID); err != nil { | ||||
| 					return nil, err | ||||
| 				} | ||||
| 			} else { | ||||
| 				if err = g.notification.GroupApplicationAgreeMemberEnterNotification(ctx, req.GroupID, nil, groupRequest.InviterUserID, req.FromUserID); err != nil { | ||||
| 					return nil, err | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 	case constant.GroupResponseRefuse: | ||||
|  | ||||
| @ -233,17 +233,17 @@ func (g *NotificationSender) groupMemberDB2PB(member *model.GroupMember, appMang | ||||
| 	return result, nil | ||||
| } */ | ||||
| 
 | ||||
| func (g *NotificationSender) fillOpUser(ctx context.Context, opUser **sdkws.GroupMemberFullInfo, groupID string) (err error) { | ||||
| 	return g.fillOpUserByUserID(ctx, mcontext.GetOpUserID(ctx), opUser, groupID) | ||||
| func (g *NotificationSender) fillOpUser(ctx context.Context, targetUser **sdkws.GroupMemberFullInfo, groupID string) (err error) { | ||||
| 	return g.fillUserByUserID(ctx, mcontext.GetOpUserID(ctx), targetUser, groupID) | ||||
| } | ||||
| 
 | ||||
| func (g *NotificationSender) fillOpUserByUserID(ctx context.Context, userID string, opUser **sdkws.GroupMemberFullInfo, groupID string) error { | ||||
| 	if opUser == nil { | ||||
| func (g *NotificationSender) fillUserByUserID(ctx context.Context, userID string, targetUser **sdkws.GroupMemberFullInfo, groupID string) error { | ||||
| 	if targetUser == nil { | ||||
| 		return errs.ErrInternalServer.WrapMsg("**sdkws.GroupMemberFullInfo is nil") | ||||
| 	} | ||||
| 	if groupID != "" { | ||||
| 		if authverify.IsManagerUserID(userID, g.config.Share.IMAdminUserID) { | ||||
| 			*opUser = &sdkws.GroupMemberFullInfo{ | ||||
| 			*targetUser = &sdkws.GroupMemberFullInfo{ | ||||
| 				GroupID:        groupID, | ||||
| 				UserID:         userID, | ||||
| 				RoleLevel:      constant.GroupAdmin, | ||||
| @ -252,7 +252,7 @@ func (g *NotificationSender) fillOpUserByUserID(ctx context.Context, userID stri | ||||
| 		} else { | ||||
| 			member, err := g.db.TakeGroupMember(ctx, groupID, userID) | ||||
| 			if err == nil { | ||||
| 				*opUser = g.groupMemberDB2PB(member, 0) | ||||
| 				*targetUser = g.groupMemberDB2PB(member, 0) | ||||
| 			} else if !(errors.Is(err, mongo.ErrNoDocuments) || errs.ErrRecordNotFound.Is(err)) { | ||||
| 				return err | ||||
| 			} | ||||
| @ -262,8 +262,8 @@ func (g *NotificationSender) fillOpUserByUserID(ctx context.Context, userID stri | ||||
| 	if err != nil { | ||||
| 		return err | ||||
| 	} | ||||
| 	if *opUser == nil { | ||||
| 		*opUser = &sdkws.GroupMemberFullInfo{ | ||||
| 	if *targetUser == nil { | ||||
| 		*targetUser = &sdkws.GroupMemberFullInfo{ | ||||
| 			GroupID:        groupID, | ||||
| 			UserID:         userID, | ||||
| 			Nickname:       user.Nickname, | ||||
| @ -271,11 +271,11 @@ func (g *NotificationSender) fillOpUserByUserID(ctx context.Context, userID stri | ||||
| 			OperatorUserID: userID, | ||||
| 		} | ||||
| 	} else { | ||||
| 		if (*opUser).Nickname == "" { | ||||
| 			(*opUser).Nickname = user.Nickname | ||||
| 		if (*targetUser).Nickname == "" { | ||||
| 			(*targetUser).Nickname = user.Nickname | ||||
| 		} | ||||
| 		if (*opUser).FaceURL == "" { | ||||
| 			(*opUser).FaceURL = user.FaceURL | ||||
| 		if (*targetUser).FaceURL == "" { | ||||
| 			(*targetUser).FaceURL = user.FaceURL | ||||
| 		} | ||||
| 	} | ||||
| 	return nil | ||||
| @ -556,15 +556,13 @@ func (g *NotificationSender) GroupApplicationAgreeMemberEnterNotification(ctx co | ||||
| 		InvitedUserList: users, | ||||
| 	} | ||||
| 	opUserID := mcontext.GetOpUserID(ctx) | ||||
| 	if err = g.fillOpUserByUserID(ctx, opUserID, &tips.OpUser, tips.Group.GroupID); err != nil { | ||||
| 	if err = g.fillUserByUserID(ctx, opUserID, &tips.OpUser, tips.Group.GroupID); err != nil { | ||||
| 		return nil | ||||
| 	} | ||||
| 	switch { | ||||
| 	case invitedOpUserID == "": | ||||
| 	case invitedOpUserID == opUserID: | ||||
| 	if invitedOpUserID == opUserID { | ||||
| 		tips.InviterUser = tips.OpUser | ||||
| 	default: | ||||
| 		if err = g.fillOpUserByUserID(ctx, invitedOpUserID, &tips.InviterUser, tips.Group.GroupID); err != nil { | ||||
| 	} else { | ||||
| 		if err = g.fillUserByUserID(ctx, invitedOpUserID, &tips.InviterUser, tips.Group.GroupID); err != nil { | ||||
| 			return err | ||||
| 		} | ||||
| 	} | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user