Advisory Database
  • Advisories
  • Dependency Scanning
  1. composer
  2. ›
  3. pocketmine/pocketmine-mp
  4. ›
  5. GMS-2023-1796

GMS-2023-1796: PocketMine-MP vulnerable to server crash using badly formatted sign NBT in BlockActorDataPacket

July 14, 2023

Summary

A player sending a packet can cause the server to crash by providing incorrect sign data in NBT in BlockActorDataPacket.

Details

This vulnerability was discovered using the BlockActorDataPacket, but other packets may also be affected. The player would seem to just need to send an NBT with an incorrect type to throw this error.

[Server thread/CRITICAL]: pocketminebt\UnexpectedTagTypeException: "Expected a tag of type pocketminebt\tag\CompoundTag, got pocketminebt\tag\ByteTag" (EXCEPTION) in "pmsrc/vendor/pocketmine/nbt/src/tag/CompoundTag" at line 107
--- Stack trace ---
 #0 pmsrc/src/network/mcpe/handler/InGamePacketHandler(751): pocketminebt\tag\CompoundTag->getCompoundTag(string[9] FrontText)
 #1 pmsrc/vendor/pocketmine/bedrock-protocol/src/BlockActorDataPacket(50): pocketmineetwork\mcpe\handler\InGamePacketHandler->handleBlockActorData(object pocketmineetwork\mcpe\protocol\BlockActorDataPacket#220241)
 #2 pmsrc/src/network/mcpe/NetworkSession(433): pocketmineetwork\mcpe\protocol\BlockActorDataPacket->handle(object pocketmineetwork\mcpe\handler\InGamePacketHandler#190572)

PoC

Use a bot or proxy to send a packet when editing a sign. This packet should contain an NBT with incorrect types but correct architecture.

Impact

This makes it possible to shutdown a server for someone who knows how to operate it. As this was discovered in 4.22.1, everyone with at least this version is affected.

Patches

This bug was fixed by 0c250a2ef09627b48aa52302f6cc7e1f2afb70ea in the 4.22.3 and 5.2.1 releases.

Workarounds

A plugin may be able to handle DataPacketReceiveEvent for BlockActorDataPacket, and verify that the FrontText tag is a TAG_Compound.

References

  • github.com/advisories/GHSA-7wrv-6h42-w54f
  • github.com/pmmp/PocketMine-MP/commit/0c250a2ef09627b48aa52302f6cc7e1f2afb70ea
  • github.com/pmmp/PocketMine-MP/security/advisories/GHSA-7wrv-6h42-w54f

Code Behaviors & Features

Detect and mitigate GMS-2023-1796 with GitLab Dependency Scanning

Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →

Affected versions

All versions starting from 4.20.0 before 4.22.3, all versions starting from 5.0.0 before 5.2.1

Fixed versions

  • 4.22.3
  • 5.2.1

Solution

Upgrade to versions 4.22.3, 5.2.1 or above.

Source file

packagist/pocketmine/pocketmine-mp/GMS-2023-1796.yml

Spotted a mistake? Edit the file on GitLab.

  • Site Repo
  • About GitLab
  • Terms
  • Privacy Statement
  • Contact

Page generated Wed, 14 May 2025 12:16:13 +0000.