mirror of
				https://github.com/luanti-org/luanti.git
				synced 2025-10-22 12:25:23 +02:00 
			
		
		
		
	GOTBLOCKS & DELETEBLOCKS: test packet size only once
This commit is contained in:
		| @@ -762,14 +762,14 @@ void Server::handleCommand_GotBlocks(NetworkPacket* pkt) | ||||
| 
 | ||||
| 	RemoteClient *client = getClient(pkt->getPeerId()); | ||||
| 
 | ||||
| 	for (u16 i = 0; i < count; i++) { | ||||
| 		if ((s16)pkt->getSize() < 1 + (i + 1) * 6) | ||||
| 			throw con::InvalidIncomingDataException | ||||
| 	if ((s16)pkt->getSize() < 1 + (int)count * 6) { | ||||
| 		throw con::InvalidIncomingDataException | ||||
| 				("GOTBLOCKS length is too short"); | ||||
| 	} | ||||
| 
 | ||||
| 	for (u16 i = 0; i < count; i++) { | ||||
| 		v3s16 p; | ||||
| 
 | ||||
| 		*pkt >> p; | ||||
| 
 | ||||
| 		client->GotBlock(p); | ||||
| 	} | ||||
| } | ||||
| @@ -865,13 +865,14 @@ void Server::handleCommand_DeletedBlocks(NetworkPacket* pkt) | ||||
| 
 | ||||
| 	RemoteClient *client = getClient(pkt->getPeerId()); | ||||
| 
 | ||||
| 	for (u16 i = 0; i < count; i++) { | ||||
| 		if ((s16)pkt->getSize() < 1 + (i + 1) * 6) | ||||
| 			throw con::InvalidIncomingDataException | ||||
| 	if ((s16)pkt->getSize() < 1 + (int)count * 6) { | ||||
| 		throw con::InvalidIncomingDataException | ||||
| 				("DELETEDBLOCKS length is too short"); | ||||
| 	} | ||||
| 
 | ||||
| 	for (u16 i = 0; i < count; i++) { | ||||
| 		v3s16 p; | ||||
| 		*pkt >> p; | ||||
| 
 | ||||
| 		client->SetBlockNotSent(p); | ||||
| 	} | ||||
| } | ||||
|   | ||||
		Reference in New Issue
	
	Block a user