mirror of
https://github.com/pmmp/PocketMine-MP.git
synced 2025-06-16 16:34:05 +00:00
Added handling for unknown packets
This commit is contained in:
parent
5aed0fb0d5
commit
e008a3cd5e
@ -174,6 +174,7 @@ use pocketmine\network\mcpe\protocol\StartGamePacket;
|
|||||||
use pocketmine\network\mcpe\protocol\TakeItemEntityPacket;
|
use pocketmine\network\mcpe\protocol\TakeItemEntityPacket;
|
||||||
use pocketmine\network\mcpe\protocol\TextPacket;
|
use pocketmine\network\mcpe\protocol\TextPacket;
|
||||||
use pocketmine\network\mcpe\protocol\TransferPacket;
|
use pocketmine\network\mcpe\protocol\TransferPacket;
|
||||||
|
use pocketmine\network\mcpe\protocol\UnknownPacket;
|
||||||
use pocketmine\network\mcpe\protocol\UpdateAttributesPacket;
|
use pocketmine\network\mcpe\protocol\UpdateAttributesPacket;
|
||||||
use pocketmine\network\mcpe\protocol\UpdateBlockPacket;
|
use pocketmine\network\mcpe\protocol\UpdateBlockPacket;
|
||||||
use pocketmine\network\mcpe\protocol\UseItemPacket;
|
use pocketmine\network\mcpe\protocol\UseItemPacket;
|
||||||
@ -3258,12 +3259,13 @@ class Player extends Human implements CommandSender, InventoryHolder, ChunkLoade
|
|||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function handleUnknown(UnknownPacket $packet) : bool{
|
||||||
|
$this->server->getLogger()->debug("Received unknown packet from " . $this->getName() . ": 0x" . bin2hex($packet->payload));
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Handles a Minecraft packet
|
* TODO: get rid of these remains, fix DataPacketReceiveEvent, fix timings
|
||||||
* TODO: Separate all of this in handlers
|
|
||||||
*
|
|
||||||
* WARNING: Do not use this, it's only for internal use.
|
|
||||||
* Changes to this function won't be recorded on the version.
|
|
||||||
*
|
*
|
||||||
* @param DataPacket $packet
|
* @param DataPacket $packet
|
||||||
*/
|
*/
|
||||||
|
@ -94,6 +94,7 @@ use pocketmine\network\mcpe\protocol\StartGamePacket;
|
|||||||
use pocketmine\network\mcpe\protocol\TakeItemEntityPacket;
|
use pocketmine\network\mcpe\protocol\TakeItemEntityPacket;
|
||||||
use pocketmine\network\mcpe\protocol\TextPacket;
|
use pocketmine\network\mcpe\protocol\TextPacket;
|
||||||
use pocketmine\network\mcpe\protocol\TransferPacket;
|
use pocketmine\network\mcpe\protocol\TransferPacket;
|
||||||
|
use pocketmine\network\mcpe\protocol\UnknownPacket;
|
||||||
use pocketmine\network\mcpe\protocol\UpdateBlockPacket;
|
use pocketmine\network\mcpe\protocol\UpdateBlockPacket;
|
||||||
use pocketmine\network\mcpe\protocol\UseItemPacket;
|
use pocketmine\network\mcpe\protocol\UseItemPacket;
|
||||||
use pocketmine\Player;
|
use pocketmine\Player;
|
||||||
@ -245,8 +246,8 @@ class Network{
|
|||||||
$buf = $stream->getString();
|
$buf = $stream->getString();
|
||||||
|
|
||||||
if(($pk = $this->getPacket(ord($buf{0}))) !== null){
|
if(($pk = $this->getPacket(ord($buf{0}))) !== null){
|
||||||
if($pk::NETWORK_ID === ProtocolInfo::BATCH_PACKET){
|
if(!$pk->canBeBatched()){
|
||||||
throw new \InvalidStateException("Invalid BatchPacket inside BatchPacket");
|
throw new \InvalidStateException("Received invalid " . get_class($pk) . " inside BatchPacket");
|
||||||
}
|
}
|
||||||
|
|
||||||
$pk->setBuffer($buf, 1);
|
$pk->setBuffer($buf, 1);
|
||||||
@ -279,7 +280,7 @@ class Network{
|
|||||||
if($class !== null){
|
if($class !== null){
|
||||||
return clone $class;
|
return clone $class;
|
||||||
}
|
}
|
||||||
return null;
|
return new UnknownPacket();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
@ -93,6 +93,7 @@ use pocketmine\network\mcpe\protocol\StartGamePacket;
|
|||||||
use pocketmine\network\mcpe\protocol\TakeItemEntityPacket;
|
use pocketmine\network\mcpe\protocol\TakeItemEntityPacket;
|
||||||
use pocketmine\network\mcpe\protocol\TextPacket;
|
use pocketmine\network\mcpe\protocol\TextPacket;
|
||||||
use pocketmine\network\mcpe\protocol\TransferPacket;
|
use pocketmine\network\mcpe\protocol\TransferPacket;
|
||||||
|
use pocketmine\network\mcpe\protocol\UnknownPacket;
|
||||||
use pocketmine\network\mcpe\protocol\UpdateAttributesPacket;
|
use pocketmine\network\mcpe\protocol\UpdateAttributesPacket;
|
||||||
use pocketmine\network\mcpe\protocol\UpdateBlockPacket;
|
use pocketmine\network\mcpe\protocol\UpdateBlockPacket;
|
||||||
use pocketmine\network\mcpe\protocol\UseItemPacket;
|
use pocketmine\network\mcpe\protocol\UseItemPacket;
|
||||||
@ -262,4 +263,6 @@ interface NetworkSession{
|
|||||||
//public function handleResourcePackChunkRequest(ResourcePackChunkRequestPacket $packet) : bool; //TODO
|
//public function handleResourcePackChunkRequest(ResourcePackChunkRequestPacket $packet) : bool; //TODO
|
||||||
|
|
||||||
public function handleTransfer(TransferPacket $packet) : bool;
|
public function handleTransfer(TransferPacket $packet) : bool;
|
||||||
|
|
||||||
|
public function handleUnknown(UnknownPacket $packet) : bool;
|
||||||
}
|
}
|
53
src/pocketmine/network/mcpe/protocol/UnknownPacket.php
Normal file
53
src/pocketmine/network/mcpe/protocol/UnknownPacket.php
Normal file
@ -0,0 +1,53 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/*
|
||||||
|
*
|
||||||
|
* ____ _ _ __ __ _ __ __ ____
|
||||||
|
* | _ \ ___ ___| | _____| |_| \/ (_)_ __ ___ | \/ | _ \
|
||||||
|
* | |_) / _ \ / __| |/ / _ \ __| |\/| | | '_ \ / _ \_____| |\/| | |_) |
|
||||||
|
* | __/ (_) | (__| < __/ |_| | | | | | | | __/_____| | | | __/
|
||||||
|
* |_| \___/ \___|_|\_\___|\__|_| |_|_|_| |_|\___| |_| |_|_|
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Lesser General Public License as published by
|
||||||
|
* the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* @author PocketMine Team
|
||||||
|
* @link http://www.pocketmine.net/
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
namespace pocketmine\network\mcpe\protocol;
|
||||||
|
|
||||||
|
|
||||||
|
use pocketmine\network\mcpe\NetworkSession;
|
||||||
|
|
||||||
|
class UnknownPacket extends DataPacket{
|
||||||
|
const NETWORK_ID = -1; //Invalid, do not try to write this
|
||||||
|
|
||||||
|
public $payload;
|
||||||
|
|
||||||
|
public function pid(){
|
||||||
|
if(strlen($this->payload ?? "") > 0){
|
||||||
|
return ord($this->payload{0});
|
||||||
|
}
|
||||||
|
return self::NETWORK_ID;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function decode(){
|
||||||
|
$this->offset -= 1; //Rewind one byte so we can read the PID
|
||||||
|
$this->payload = $this->get(true);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function encode(){
|
||||||
|
//Do not reset the buffer, this class does not have a valid NETWORK_ID constant.
|
||||||
|
$this->put($this->payload);
|
||||||
|
}
|
||||||
|
|
||||||
|
public function handle(NetworkSession $session) : bool{
|
||||||
|
return $session->handleUnknown($this);
|
||||||
|
}
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user