mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-10-16 03:51:37 +00:00
PacketBatch: added a getPackets() method which encapsulates some logic
This commit is contained in:
@@ -98,7 +98,6 @@ use pocketmine\player\Player;
|
||||
use pocketmine\player\PlayerInfo;
|
||||
use pocketmine\Server;
|
||||
use pocketmine\timings\Timings;
|
||||
use pocketmine\utils\BinaryDataException;
|
||||
use pocketmine\utils\TextFormat;
|
||||
use pocketmine\utils\Utils;
|
||||
use pocketmine\world\Position;
|
||||
@@ -328,24 +327,18 @@ class NetworkSession{
|
||||
Timings::$playerNetworkReceiveDecompressTimer->stopTiming();
|
||||
}
|
||||
|
||||
$count = 0;
|
||||
while(!$stream->feof() and $this->connected){
|
||||
if($count++ >= 500){
|
||||
throw new BadPacketException("Too many packets in a single batch");
|
||||
}
|
||||
try{
|
||||
$pk = $stream->getPacket($this->packetPool);
|
||||
}catch(BinaryDataException $e){
|
||||
$this->logger->debug("Packet batch: " . base64_encode($stream->getBuffer()));
|
||||
throw BadPacketException::wrap($e, "Packet batch decode error");
|
||||
}
|
||||
|
||||
try{
|
||||
$this->handleDataPacket($pk);
|
||||
}catch(BadPacketException $e){
|
||||
$this->logger->debug($pk->getName() . ": " . base64_encode($pk->getSerializer()->getBuffer()));
|
||||
throw BadPacketException::wrap($e, "Error processing " . $pk->getName());
|
||||
try{
|
||||
foreach($stream->getPackets($this->packetPool, 500) as $packet){
|
||||
try{
|
||||
$this->handleDataPacket($packet);
|
||||
}catch(BadPacketException $e){
|
||||
$this->logger->debug($packet->getName() . ": " . base64_encode($packet->getSerializer()->getBuffer()));
|
||||
throw BadPacketException::wrap($e, "Error processing " . $packet->getName());
|
||||
}
|
||||
}
|
||||
}catch(PacketDecodeException $e){
|
||||
$this->logger->logException($e);
|
||||
throw BadPacketException::wrap($e, "Packet batch decode error");
|
||||
}
|
||||
}
|
||||
|
||||
|
@@ -24,6 +24,7 @@ declare(strict_types=1);
|
||||
namespace pocketmine\network\mcpe\protocol\serializer;
|
||||
|
||||
use pocketmine\network\mcpe\protocol\Packet;
|
||||
use pocketmine\network\mcpe\protocol\PacketDecodeException;
|
||||
use pocketmine\network\mcpe\protocol\PacketPool;
|
||||
use pocketmine\utils\BinaryDataException;
|
||||
|
||||
@@ -48,6 +49,19 @@ class PacketBatch{
|
||||
return $packetPool->getPacket($this->serializer->getString());
|
||||
}
|
||||
|
||||
/**
|
||||
* @return \Generator|Packet[]
|
||||
* @phpstan-return \Generator<int, Packet, void, void>
|
||||
*/
|
||||
public function getPackets(PacketPool $packetPool, int $max) : \Generator{
|
||||
for($c = 0; $c < $max and !$this->serializer->feof(); ++$c){
|
||||
yield $c => $packetPool->getPacket($this->serializer->getString());
|
||||
}
|
||||
if(!$this->serializer->feof()){
|
||||
throw new PacketDecodeException("Reached limit of $max packets in a single batch");
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Constructs a packet batch from the given list of packets.
|
||||
*
|
||||
|
Reference in New Issue
Block a user