From 888c2765037711f45a6dac8d8bad70dc9ee70998 Mon Sep 17 00:00:00 2001 From: Shayne Hartford Date: Mon, 4 Dec 2023 15:26:53 -0500 Subject: Add masked chat type/event (#118) --- azalea-client/src/chat.rs | 14 ++++++++++++++ azalea-client/src/packet_handling/game.rs | 13 ++++++++++++- 2 files changed, 26 insertions(+), 1 deletion(-) (limited to 'azalea-client/src') diff --git a/azalea-client/src/chat.rs b/azalea-client/src/chat.rs index f805c20f..255e0898 100755 --- a/azalea-client/src/chat.rs +++ b/azalea-client/src/chat.rs @@ -2,6 +2,7 @@ use azalea_chat::FormattedText; use azalea_protocol::packets::game::{ + clientbound_disguised_chat_packet::ClientboundMaskedChatPacket, clientbound_player_chat_packet::ClientboundPlayerChatPacket, clientbound_system_chat_packet::ClientboundSystemChatPacket, serverbound_chat_command_packet::ServerboundChatCommandPacket, @@ -30,6 +31,7 @@ use crate::{ pub enum ChatPacket { System(Arc), Player(Arc), + Masked(Arc), } macro_rules! regex { @@ -45,6 +47,7 @@ impl ChatPacket { match self { ChatPacket::System(p) => p.content.clone(), ChatPacket::Player(p) => p.message(), + ChatPacket::Masked(p) => p.message.clone(), } } @@ -72,6 +75,16 @@ impl ChatPacket { return (Some(m[1].to_string()), m[2].to_string()); } + (None, message) + } + ChatPacket::Masked(p) => { + let message = p.message.to_string(); + // It's a system message, so we'll have to match the content + // with regex + if let Some(m) = regex!("^<([a-zA-Z_0-9]{1,16})> (.+)$").captures(&message) { + return (Some(m[1].to_string()), m[2].to_string()); + } + (None, message) } } @@ -91,6 +104,7 @@ impl ChatPacket { match self { ChatPacket::System(_) => None, ChatPacket::Player(m) => Some(m.sender), + ChatPacket::Masked(_) => None, } } diff --git a/azalea-client/src/packet_handling/game.rs b/azalea-client/src/packet_handling/game.rs index 20facadb..6c4ea4f4 100644 --- a/azalea-client/src/packet_handling/game.rs +++ b/azalea-client/src/packet_handling/game.rs @@ -1382,7 +1382,18 @@ pub fn process_packet_events(ecs: &mut World) { ClientboundGamePacket::TabList(_) => {} ClientboundGamePacket::TagQuery(_) => {} ClientboundGamePacket::TakeItemEntity(_) => {} - ClientboundGamePacket::DisguisedChat(_) => {} + ClientboundGamePacket::MaskedChat(p) => { + debug!("Got masked chat packet {p:?}"); + + let mut system_state: SystemState> = + SystemState::new(ecs); + let mut chat_events = system_state.get_mut(ecs); + + chat_events.send(ChatReceivedEvent { + entity: player_entity, + packet: ChatPacket::Masked(Arc::new(p.clone())), + }); + } ClientboundGamePacket::Bundle(_) => {} ClientboundGamePacket::DamageEvent(_) => {} ClientboundGamePacket::HurtAnimation(_) => {} -- cgit v1.2.3