8.8 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	For Minecraft: Bedrock Edition 1.19.70
Note about API versions
Plugins which don't touch the pocketmine\network\mcpe namespace are compatible with any previous 4.x.y version will also run on these releases and do not need API bumps.
Plugin developers should only update their required API to this version if you need the changes in this build.
WARNING: If your plugin uses the pocketmine\network\mcpe namespace, you're not shielded by API change constraints.
Consider using the mcpe-protocol directive in plugin.yml as a constraint if you're using packets directly.
Highlights
This version significantly improves server performance with many players and/or entities by making changes to the internal network system.
It also introduces support for the newer ItemStackRequest protocol, which fixes many bugs and improves server security.
While these changes don't affect non-internal API, they are still significant enough to warrant a new minor version, as they may break plugins which use the internal network API (not recommended).
4.18.0
Released 25th March 2023.
General
- Significantly improved server performance in congested areas of the world (lots of players and/or entities in the same area).
- Included more sections of the network system in Player Network Sendperformance timings.
- Changed the names of some performance timings to make them more user-friendly.
- Removed packet IDs from receivePacketandsendPacketperformance timings, as they were not very useful.
- Added new specialized performance timings for the following:
- Item entity base ticking (merging)
- Player movement processing
- Entity movement processing (collision checking section)
- Projectile movement (all)
- Projectile movement processing (ray tracing section)
 
API
pocketmine\crafting
- The following new API methods have been added:
- CraftingManager->getCraftingRecipeIndex() : array<int, CraftingRecipe>- returns a list of all crafting recipes
- CraftingManager->getCraftingRecipeFromIndex(int $index) : ?CraftingRecipe- returns the crafting recipe at the given index, or null if it doesn't exist
 
pocketmine\event\server
- The following new classes have been added:
- DataPacketDecodeEvent- called before a packet is decoded by a- NetworkSession; useful to mitigate DoS attacks if PocketMine-MP hasn't been patched against new bugs yet
 
pocketmine\inventory\transaction
- The following API methods have changed signatures:
- CraftingTransaction->__construct()now accepts additional arguments- ?CraftingRecipe $recipe = null, ?int $repetitions = null
 
- The following new API methods have been added:
- TransactionBuilderInventory->getActualInventory() : Inventory- returns the actual inventory that this inventory is a proxy for
 
Internals
Network
- Introduced new system for broadcasting entity events to network sessions.
- This change improves performance when lots of players and/or entities are in the same area.
- New interface EntityEventBroadcasterand classStandardEntityEventBroadcasterhave been added to implement this.
- All entity-specific on*()andsync*()methods have been removed fromNetworkSession(internals backwards compatibility break, not covered by API version guarantee).
- NetworkSessionnow accepts an- EntityEventBroadcasterinstance in its constructor.
- NetworkBroadcastUtils::broadcastEntityEvent()can be used to efficiently broadcast events to unique broadcasters shared by several network sessions.
 
- All network sessions now share the same PacketSerializerContextandPacketBroadcasterby default.- Previously, every session had its own context, meaning that broadcast optimisations were not used, causing significant performance losses compared to 3.x.
- This change improves performance in congested areas by allowing reuse of previously encoded packet buffers for all sessions sharing the same context.
- Packet broadcasts are automatically encoded separately per unique PacketSerializerContextinstance. This allows, for example, a multi-version fork to have a separate context for each protocol version, to ensure maximum broadcast efficiency while encoding different packets for different versions.
- PacketSerializerContextis now passed in- NetworkSession::__construct(), instead of being created by the session.
 
- StandardPacketBroadcasteris now locked to a single- PacketSerializercontext, reducing complexity.
- Introduced NetworkBroadcastUtils::broadcastPackets(), replacingServer->broadcastPackets().
- Server->broadcastPackets()has been deprecated. It will be removed in a future version.
- Introduced support for the ItemStackRequestMinecraft: Bedrock network protocol.- This fixes a large number of inventory- and crafting-related bugs.
- This also improves server security by closing off many code pathways that might have been used for exploits. TypeConverter->netItemStackToCore()is no longer used in server code, and remains for tool usage only.
- This system is also significantly more bandwidth-efficient and has lower overhead than the legacy system.
- This now opens the gateway to easily implement lots of gameplay features which have been missing for a long time, such as enchanting, anvils, looms, and more.
- Significant changes have been made to pocketmine\network\mcpe\InventoryManagerinternals. These shouldn't affect plugins, but may affect plugins which use internal network API.
- No changes have been made to the plugin InventoryTransactionAPI.- This system has been implemented as a shim for the existing PocketMine-MP transaction system to preserve plugin compatibility. Plugins using InventoryTransactionEventshould continue to work seamlessly.
- The InventoryTransactionAPI will be redesigned in a future major version to make use of the new information provided by theItemStackRequestsystem.
 
- This system has been implemented as a shim for the existing PocketMine-MP transaction system to preserve plugin compatibility. Plugins using 
- InventoryTransactionPacketis no longer sent by the client for "regular" inventory actions. However, it is still sent when dropping items, interacting with blocks, and using items.
 
- Inventory slot and content syncing is now buffered until the end of the tick. This reduces outbound network usage when the client performs multiple transactions in a single tick (e.g. crafting a stack of items).
- Renamed some InventoryManagerinternal properties to make them easier to understand.
- TypeConverter->createInventoryAction()has been removed.
- Packet batch limit has been lowered to 100packets. With the introduction ofItemStackRequest, this is more than sufficient for normal gameplay.
Other
- Use Vector3::zero()instead ofnew Vector3()in some places.
4.18.1
Released 27th March 2023.
General
- RakLibInterfacenow logs the name of the currently active session if a crash occurs when processing a packet. This makes it easier to reproduce bugs, which is important to be able to fix them.
- Added more detailed debugging information to InventoryManager->syncSelectedHotbarSlot().
Fixes
- Fixed server crash when attempting to drop more of an item from a stack than available in the inventory.
- Fixed packet processing errors when editing writable books.
- Fixed packet processing errors when shift-clicking on the recipe book to craft recipes which draw from a large number of inventory slots.
4.18.2
Released 29th March 2023.
Fixes
- Fixed players being unable to join due to the appearance of a new x5tfield in the JWT header of Xbox Live authentication tokens.
- Fixed items' durability appearing to reset when moving them around in the inventory.
4.18.3
Released 5th April 2023.
Fixes
- Fixed Average Players not being shown on timings reports when custom player classes are used.
- Fixed incorrect tick violation calculation in timings reports.
- Fixed not being able to add or remove items from the offhand slot.
- Fixed creative inventory item count corruption when taking items (some players would see 64x items in the creative inventory after rejoining or changing gamemode).
- Fixed not being able to drop items directly from the creative inventory on mobile.
- Fixed DataPacketReceiveEventnot being called for packets sent byEntityEventBroadcaster.
- CreativeInventory::getItem()and- CreativeInventory::getAll()now return cloned itemstacks, to prevent accidental modification of the creative inventory.
4.18.4
Released 10th April 2023.
Fixes
- Fixed movement becoming broken when the player moves at high speed (e.g. due to high levels of the Speed effect).
- Updated dependencies to get fixes in pocketmine/nbtandpocketmine/bedrock-protocol.
Internals
Network
- Game packets are now rate-limited in a similar manner to packet batches. This helps to more effectively mitigate certain types of DoS attacks.
- Added a new class PacketRateLimiter, implementing functionality previously baked directly intoNetworkSessionin a more generic way to allow reuse.