mirror of
				https://github.com/openimsdk/open-im-server.git
				synced 2025-10-25 20:52:11 +08:00 
			
		
		
		
	fix: fix incorrect ws check logic.
This commit is contained in:
		
							parent
							
								
									4ae05d2e38
								
							
						
					
					
						commit
						a0cbd924bb
					
				| @ -249,6 +249,7 @@ func (s *Server) MultiTerminalLoginCheck(ctx context.Context, req *msggateway.Mu | ||||
| 		tempUserCtx.SetOperationID(mcontext.GetOperationID(ctx)) | ||||
| 		client := &Client{} | ||||
| 		client.ctx = tempUserCtx | ||||
| 		client.token = req.Token | ||||
| 		client.UserID = req.UserID | ||||
| 		client.PlatformID = int(req.PlatformID) | ||||
| 		i := &kickHandler{ | ||||
|  | ||||
| @ -334,6 +334,24 @@ func (ws *WsServer) multiTerminalLoginChecker(clientOK bool, oldClients []*Clien | ||||
| 		} | ||||
| 	} | ||||
| 
 | ||||
| 	checkFunc := func(oldClients []*Client) []*Client { | ||||
| 		var clientsToKick []*Client | ||||
| 
 | ||||
| 		for _, c := range oldClients { | ||||
| 			if c.token == newClient.token { | ||||
| 				log.ZDebug(newClient.ctx, "token is same, not kick", | ||||
| 					"userID", newClient.UserID, | ||||
| 					"platformID", newClient.PlatformID, | ||||
| 					"token", newClient.token) | ||||
| 				continue | ||||
| 			} | ||||
| 
 | ||||
| 			clientsToKick = append(clientsToKick, c) | ||||
| 		} | ||||
| 
 | ||||
| 		return clientsToKick | ||||
| 	} | ||||
| 
 | ||||
| 	switch ws.msgGatewayConfig.Share.MultiLogin.Policy { | ||||
| 	case constant.DefalutNotKick: | ||||
| 	case constant.PCAndOther: | ||||
| @ -349,11 +367,14 @@ func (ws *WsServer) multiTerminalLoginChecker(clientOK bool, oldClients []*Clien | ||||
| 			} | ||||
| 			oldClients = append(oldClients, c) | ||||
| 		} | ||||
| 		oldClients = checkFunc(oldClients) | ||||
| 		fallthrough | ||||
| 	case constant.AllLoginButSameTermKick: | ||||
| 		if !clientOK { | ||||
| 			return | ||||
| 		} | ||||
| 		oldClients = checkFunc(oldClients) | ||||
| 
 | ||||
| 		ws.clients.DeleteClients(newClient.UserID, oldClients) | ||||
| 		for _, c := range oldClients { | ||||
| 			err := c.KickOnlineMessage() | ||||
| @ -384,9 +405,13 @@ func (ws *WsServer) multiTerminalLoginChecker(clientOK bool, oldClients []*Clien | ||||
| 		) | ||||
| 		for _, client := range clients { | ||||
| 			if constant.PlatformIDToClass(client.PlatformID) == constant.PlatformIDToClass(newClient.PlatformID) { | ||||
| 				{ | ||||
| 					kickClients = append(kickClients, client) | ||||
| 				} | ||||
| 			} | ||||
| 		} | ||||
| 		kickClients = checkFunc(kickClients) | ||||
| 
 | ||||
| 		kickTokenFunc(kickClients) | ||||
| 	} | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user