Commit 1ab9273a by Jonathan Thomas

Added NULL checks on client message listeners (to prevent crashes for invalid or…

Added NULL checks on client message listeners (to prevent crashes for invalid or uninitialized clients)
parent 6c5fa825
Pipeline #13211 passed with stages
in 2 minutes 6 seconds
...@@ -24,6 +24,7 @@ All notable changes to **CreatureChat** are documented in this file. The format ...@@ -24,6 +24,7 @@ All notable changes to **CreatureChat** are documented in this file. The format
- Protect now auto sets friendship to 1 (if <= 0), to prevent entity from attacking and protecting at the same time - Protect now auto sets friendship to 1 (if <= 0), to prevent entity from attacking and protecting at the same time
- Seperated `generateCharacter()` and `generateMessage()` functions for simplicity - Seperated `generateCharacter()` and `generateMessage()` functions for simplicity
- Fixing PACKET_S2C_MESSAGE from crashing a newly logging on player, if they receive that message first. - Fixing PACKET_S2C_MESSAGE from crashing a newly logging on player, if they receive that message first.
- Added NULL checks on client message listeners (to prevent crashes for invalid or uninitialized clients)
### Fixed ### Fixed
- Fixed a regression caused by adding a "-forge" suffix to one of our builds - Fixed a regression caused by adding a "-forge" suffix to one of our builds
......
...@@ -120,14 +120,15 @@ public class ClientPackets { ...@@ -120,14 +120,15 @@ public class ClientPackets {
// Update the chat data manager on the client-side // Update the chat data manager on the client-side
client.execute(() -> { // Make sure to run on the client thread client.execute(() -> { // Make sure to run on the client thread
// Ensure client.player is initialized // Ensure client.player is initialized
if (client.player == null) { if (client.player == null || client.world == null) {
LOGGER.warn("Client player is not initialized. Dropping message for entity '{}'.", entityId); LOGGER.warn("Client not fully initialized. Dropping message for entity '{}'.", entityId);
return; return;
} }
// Update the chat data manager on the client-side // Update the chat data manager on the client-side
MobEntity entity = ClientEntityFinder.getEntityByUUID(client.world, entityId); MobEntity entity = ClientEntityFinder.getEntityByUUID(client.world, entityId);
if (entity == null) { if (entity == null) {
LOGGER.warn("Entity with ID '{}' not found. Skipping message processing.", entityId);
return; return;
} }
...@@ -183,8 +184,8 @@ public class ClientPackets { ...@@ -183,8 +184,8 @@ public class ClientPackets {
// Decompress the combined byte array to get the original JSON string // Decompress the combined byte array to get the original JSON string
String chatDataJSON = Decompression.decompressString(combined.toByteArray()); String chatDataJSON = Decompression.decompressString(combined.toByteArray());
if (chatDataJSON == null) { if (chatDataJSON == null || chatDataJSON.isEmpty()) {
LOGGER.info("Error decompressing lite JSON string from bytes"); LOGGER.warn("Received invalid or empty chat data JSON. Skipping processing.");
return; return;
} }
...@@ -231,7 +232,12 @@ public class ClientPackets { ...@@ -231,7 +232,12 @@ public class ClientPackets {
PlayerEntity player = ClientEntityFinder.getPlayerEntityFromUUID(playerId); PlayerEntity player = ClientEntityFinder.getPlayerEntityFromUUID(playerId);
// Update the player status data manager on the client-side // Update the player status data manager on the client-side
client.execute(() -> { // Make sure to run on the client thread client.execute(() -> {
if (player == null) {
LOGGER.warn("Player entity is null. Skipping status update.");
return;
}
if (isChatOpen) { if (isChatOpen) {
PlayerMessageManager.openChatUI(playerId); PlayerMessageManager.openChatUI(playerId);
playNearbyUISound(client, player, 0.2f); playNearbyUISound(client, player, 0.2f);
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment