Skip to content

Commit

Permalink
Revive TickSyncPacket
Browse files Browse the repository at this point in the history
  • Loading branch information
dries-c committed Jun 14, 2024
1 parent 2d2bdc6 commit d3077c6
Showing 1 changed file with 53 additions and 1 deletion.
54 changes: 53 additions & 1 deletion data/TickSyncPacket.php
Original file line number Diff line number Diff line change
Expand Up @@ -7,10 +7,62 @@
use libproxy\ProxyNetworkInterface;
use pocketmine\network\mcpe\handler\InGamePacketHandler;
use pocketmine\network\mcpe\NetworkSession;
use pocketmine\network\mcpe\protocol\ClientboundPacket;
use pocketmine\network\mcpe\protocol\DataPacket;
use pocketmine\network\mcpe\protocol\PacketHandlerInterface;
use pocketmine\network\mcpe\protocol\serializer\PacketSerializer;
use pocketmine\network\mcpe\protocol\ServerboundPacket;

class TickSyncPacket extends \pocketmine\network\mcpe\protocol\TickSyncPacket
class TickSyncPacket extends DataPacket implements ClientboundPacket, ServerboundPacket
{
public const NETWORK_ID = 0x17;

private int $clientSendTime;
private int $serverReceiveTime;

/**
* @generate-create-func
*/
private static function create(int $clientSendTime, int $serverReceiveTime): self
{
$result = new self;
$result->clientSendTime = $clientSendTime;
$result->serverReceiveTime = $serverReceiveTime;
return $result;
}

public static function request(int $clientTime): self
{
return self::create($clientTime, 0 /* useless, but always written anyway */);
}

public static function response(int $clientSendTime, int $serverReceiveTime): self
{
return self::create($clientSendTime, $serverReceiveTime);
}

public function getClientSendTime(): int
{
return $this->clientSendTime;
}

public function getServerReceiveTime(): int
{
return $this->serverReceiveTime;
}

protected function decodePayload(PacketSerializer $in): void
{
$this->clientSendTime = $in->getLLong();
$this->serverReceiveTime = $in->getLLong();
}

protected function encodePayload(PacketSerializer $out): void
{
$out->putLLong($this->clientSendTime);
$out->putLLong($this->serverReceiveTime);
}

public function handle(PacketHandlerInterface $handler): bool
{
if (!($handler instanceof InGamePacketHandler)) {
Expand Down

0 comments on commit d3077c6

Please sign in to comment.