mirror of
https://github.com/MCCTeam/Minecraft-Console-Client
synced 2025-11-07 17:36:07 +00:00
Server Data and Profileless Chat message packets implemented. ChatPreview packet removed. Message Header packet set only to 1.19.2. Chat Message packet partially implemented.
This commit is contained in:
parent
d81a67762e
commit
bb160d6d84
2 changed files with 143 additions and 80 deletions
15
MinecraftClient/Mapping/MessageFilterType.cs
Normal file
15
MinecraftClient/Mapping/MessageFilterType.cs
Normal file
|
|
@ -0,0 +1,15 @@
|
||||||
|
using System;
|
||||||
|
using System.Collections.Generic;
|
||||||
|
using System.Linq;
|
||||||
|
using System.Text;
|
||||||
|
using System.Threading.Tasks;
|
||||||
|
|
||||||
|
namespace MinecraftClient.Mapping
|
||||||
|
{
|
||||||
|
public enum MessageFilterType
|
||||||
|
{
|
||||||
|
PassThrough = 0,
|
||||||
|
FullyFiltered,
|
||||||
|
PartiallyFiltered
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
@ -522,80 +522,126 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
}
|
}
|
||||||
else // 1.19.1 +
|
else // 1.19.1 +
|
||||||
{
|
{
|
||||||
byte[]? precedingSignature = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextByteArray(packetData) : null;
|
if (protocolVersion >= MC_1_19_3_Version)
|
||||||
Guid senderUUID = dataTypes.ReadNextUUID(packetData);
|
|
||||||
byte[] headerSignature = dataTypes.ReadNextByteArray(packetData);
|
|
||||||
|
|
||||||
string signedChat = dataTypes.ReadNextString(packetData);
|
|
||||||
string? decorated = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextString(packetData) : null;
|
|
||||||
|
|
||||||
long timestamp = dataTypes.ReadNextLong(packetData);
|
|
||||||
long salt = dataTypes.ReadNextLong(packetData);
|
|
||||||
|
|
||||||
int lastSeenMessageListLen = dataTypes.ReadNextVarInt(packetData);
|
|
||||||
LastSeenMessageList.Entry[] lastSeenMessageList = new LastSeenMessageList.Entry[lastSeenMessageListLen];
|
|
||||||
for (int i = 0; i < lastSeenMessageListLen; ++i)
|
|
||||||
{
|
{
|
||||||
Guid user = dataTypes.ReadNextUUID(packetData);
|
// Header section
|
||||||
byte[] lastSignature = dataTypes.ReadNextByteArray(packetData);
|
Guid senderUUID = dataTypes.ReadNextUUID(packetData);
|
||||||
lastSeenMessageList[i] = new(user, lastSignature);
|
int index = dataTypes.ReadNextVarInt(packetData);
|
||||||
}
|
byte[]? messageSignature = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextByteArray(packetData) : null;
|
||||||
LastSeenMessageList lastSeenMessages = new(lastSeenMessageList);
|
|
||||||
|
|
||||||
string? unsignedChatContent = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextString(packetData) : null;
|
// Body
|
||||||
|
string message = dataTypes.ReadNextString(packetData);
|
||||||
|
long timestamp = dataTypes.ReadNextLong(packetData);
|
||||||
|
long salt = dataTypes.ReadNextLong(packetData);
|
||||||
|
|
||||||
int filterEnum = dataTypes.ReadNextVarInt(packetData);
|
// Previous Messages
|
||||||
if (filterEnum == 2) // PARTIALLY_FILTERED
|
int totalPreviousMessages = dataTypes.ReadNextVarInt(packetData);
|
||||||
dataTypes.ReadNextULongArray(packetData);
|
List<Byte[]> previousMessageSignatures = new();
|
||||||
|
|
||||||
int chatTypeId = dataTypes.ReadNextVarInt(packetData);
|
for (int i = 0; i < totalPreviousMessages; i++)
|
||||||
string chatName = dataTypes.ReadNextString(packetData);
|
|
||||||
string? targetName = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextString(packetData) : null;
|
|
||||||
|
|
||||||
Dictionary<string, Json.JSONData> chatInfo = Json.ParseJson(chatName).Properties;
|
|
||||||
string senderDisplayName = (chatInfo.ContainsKey("insertion") ? chatInfo["insertion"] : chatInfo["text"]).StringValue;
|
|
||||||
string? senderTeamName = null;
|
|
||||||
ChatParser.MessageType messageTypeEnum = ChatParser.ChatId2Type!.GetValueOrDefault(chatTypeId, ChatParser.MessageType.CHAT);
|
|
||||||
if (targetName != null &&
|
|
||||||
(messageTypeEnum == ChatParser.MessageType.TEAM_MSG_COMMAND_INCOMING || messageTypeEnum == ChatParser.MessageType.TEAM_MSG_COMMAND_OUTGOING))
|
|
||||||
senderTeamName = Json.ParseJson(targetName).Properties["with"].DataArray[0].Properties["text"].StringValue;
|
|
||||||
|
|
||||||
if (string.IsNullOrWhiteSpace(senderDisplayName))
|
|
||||||
{
|
|
||||||
PlayerInfo? player = handler.GetPlayerInfo(senderUUID);
|
|
||||||
if (player != null && (player.DisplayName != null || player.Name != null) && string.IsNullOrWhiteSpace(senderDisplayName))
|
|
||||||
{
|
{
|
||||||
senderDisplayName = ChatParser.ParseText(player.DisplayName ?? player.Name);
|
int messageId = dataTypes.ReadNextVarInt(packetData);
|
||||||
if (string.IsNullOrWhiteSpace(senderDisplayName))
|
|
||||||
senderDisplayName = player.DisplayName ?? player.Name;
|
|
||||||
else
|
|
||||||
senderDisplayName += "§r";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
bool verifyResult;
|
if (messageId > 0)
|
||||||
if (!isOnlineMode)
|
previousMessageSignatures.Add(dataTypes.ReadNextByteArray(packetData));
|
||||||
verifyResult = false;
|
}
|
||||||
else if (senderUUID == handler.GetUserUuid())
|
|
||||||
verifyResult = true;
|
// Other
|
||||||
|
string? unsignedChatContent = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextString(packetData) : null;
|
||||||
|
|
||||||
|
MessageFilterType filterType = (MessageFilterType)dataTypes.ReadNextVarInt(packetData);
|
||||||
|
|
||||||
|
if (filterType == MessageFilterType.PartiallyFiltered)
|
||||||
|
dataTypes.ReadNextULongArray(packetData);
|
||||||
|
|
||||||
|
// Network Target
|
||||||
|
int chatType = dataTypes.ReadNextInt(packetData);
|
||||||
|
string networkName = dataTypes.ReadNextString(packetData);
|
||||||
|
bool networkTargetNamePresent = dataTypes.ReadNextBool(packetData);
|
||||||
|
string? networkTargetName = null;
|
||||||
|
|
||||||
|
if (networkTargetNamePresent)
|
||||||
|
networkTargetName = dataTypes.ReadNextString(packetData);
|
||||||
|
|
||||||
|
// TODO
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
PlayerInfo? player = handler.GetPlayerInfo(senderUUID);
|
byte[]? precedingSignature = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextByteArray(packetData) : null;
|
||||||
if (player == null || !player.IsMessageChainLegal())
|
Guid senderUUID = dataTypes.ReadNextUUID(packetData);
|
||||||
|
byte[] headerSignature = dataTypes.ReadNextByteArray(packetData);
|
||||||
|
|
||||||
|
string signedChat = dataTypes.ReadNextString(packetData);
|
||||||
|
string? decorated = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextString(packetData) : null;
|
||||||
|
|
||||||
|
long timestamp = dataTypes.ReadNextLong(packetData);
|
||||||
|
long salt = dataTypes.ReadNextLong(packetData);
|
||||||
|
|
||||||
|
int lastSeenMessageListLen = dataTypes.ReadNextVarInt(packetData);
|
||||||
|
LastSeenMessageList.Entry[] lastSeenMessageList = new LastSeenMessageList.Entry[lastSeenMessageListLen];
|
||||||
|
for (int i = 0; i < lastSeenMessageListLen; ++i)
|
||||||
|
{
|
||||||
|
Guid user = dataTypes.ReadNextUUID(packetData);
|
||||||
|
byte[] lastSignature = dataTypes.ReadNextByteArray(packetData);
|
||||||
|
lastSeenMessageList[i] = new(user, lastSignature);
|
||||||
|
}
|
||||||
|
LastSeenMessageList lastSeenMessages = new(lastSeenMessageList);
|
||||||
|
|
||||||
|
string? unsignedChatContent = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextString(packetData) : null;
|
||||||
|
|
||||||
|
MessageFilterType filterEnum = (MessageFilterType)dataTypes.ReadNextVarInt(packetData);
|
||||||
|
if (filterEnum == MessageFilterType.PartiallyFiltered)
|
||||||
|
dataTypes.ReadNextULongArray(packetData);
|
||||||
|
|
||||||
|
int chatTypeId = dataTypes.ReadNextVarInt(packetData);
|
||||||
|
string chatName = dataTypes.ReadNextString(packetData);
|
||||||
|
string? targetName = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextString(packetData) : null;
|
||||||
|
|
||||||
|
Dictionary<string, Json.JSONData> chatInfo = Json.ParseJson(chatName).Properties;
|
||||||
|
string senderDisplayName = (chatInfo.ContainsKey("insertion") ? chatInfo["insertion"] : chatInfo["text"]).StringValue;
|
||||||
|
string? senderTeamName = null;
|
||||||
|
ChatParser.MessageType messageTypeEnum = ChatParser.ChatId2Type!.GetValueOrDefault(chatTypeId, ChatParser.MessageType.CHAT);
|
||||||
|
if (targetName != null &&
|
||||||
|
(messageTypeEnum == ChatParser.MessageType.TEAM_MSG_COMMAND_INCOMING || messageTypeEnum == ChatParser.MessageType.TEAM_MSG_COMMAND_OUTGOING))
|
||||||
|
senderTeamName = Json.ParseJson(targetName).Properties["with"].DataArray[0].Properties["text"].StringValue;
|
||||||
|
|
||||||
|
if (string.IsNullOrWhiteSpace(senderDisplayName))
|
||||||
|
{
|
||||||
|
PlayerInfo? player = handler.GetPlayerInfo(senderUUID);
|
||||||
|
if (player != null && (player.DisplayName != null || player.Name != null) && string.IsNullOrWhiteSpace(senderDisplayName))
|
||||||
|
{
|
||||||
|
senderDisplayName = ChatParser.ParseText(player.DisplayName ?? player.Name);
|
||||||
|
if (string.IsNullOrWhiteSpace(senderDisplayName))
|
||||||
|
senderDisplayName = player.DisplayName ?? player.Name;
|
||||||
|
else
|
||||||
|
senderDisplayName += "§r";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
bool verifyResult;
|
||||||
|
if (!isOnlineMode)
|
||||||
verifyResult = false;
|
verifyResult = false;
|
||||||
|
else if (senderUUID == handler.GetUserUuid())
|
||||||
|
verifyResult = true;
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
bool lastVerifyResult = player.IsMessageChainLegal();
|
PlayerInfo? player = handler.GetPlayerInfo(senderUUID);
|
||||||
verifyResult = player.VerifyMessage(signedChat, timestamp, salt, ref headerSignature, ref precedingSignature, lastSeenMessages);
|
if (player == null || !player.IsMessageChainLegal())
|
||||||
if (lastVerifyResult && !verifyResult)
|
verifyResult = false;
|
||||||
log.Warn(string.Format(Translations.chat_message_chain_broken, senderDisplayName));
|
else
|
||||||
|
{
|
||||||
|
bool lastVerifyResult = player.IsMessageChainLegal();
|
||||||
|
verifyResult = player.VerifyMessage(signedChat, timestamp, salt, ref headerSignature, ref precedingSignature, lastSeenMessages);
|
||||||
|
if (lastVerifyResult && !verifyResult)
|
||||||
|
log.Warn(string.Format(Translations.chat_message_chain_broken, senderDisplayName));
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
|
||||||
|
|
||||||
ChatMessage chat = new(signedChat, false, chatTypeId, senderUUID, unsignedChatContent, senderDisplayName, senderTeamName, timestamp, headerSignature, verifyResult);
|
ChatMessage chat = new(signedChat, false, chatTypeId, senderUUID, unsignedChatContent, senderDisplayName, senderTeamName, timestamp, headerSignature, verifyResult);
|
||||||
if (isOnlineMode && !chat.LacksSender())
|
if (isOnlineMode && !chat.LacksSender())
|
||||||
Acknowledge(chat);
|
Acknowledge(chat);
|
||||||
handler.OnTextReceived(chat);
|
handler.OnTextReceived(chat);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case PacketTypesIn.CombatEvent:
|
case PacketTypesIn.CombatEvent:
|
||||||
|
|
@ -625,8 +671,8 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
);
|
);
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case PacketTypesIn.MessageHeader:
|
case PacketTypesIn.MessageHeader: // 1.19.2 only
|
||||||
if (protocolVersion >= MC_1_19_2_Version)
|
if (protocolVersion == MC_1_19_2_Version)
|
||||||
{
|
{
|
||||||
byte[]? precedingSignature = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextByteArray(packetData) : null;
|
byte[]? precedingSignature = dataTypes.ReadNextBool(packetData) ? dataTypes.ReadNextByteArray(packetData) : null;
|
||||||
Guid senderUUID = dataTypes.ReadNextUUID(packetData);
|
Guid senderUUID = dataTypes.ReadNextUUID(packetData);
|
||||||
|
|
@ -654,6 +700,7 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case PacketTypesIn.Respawn:
|
case PacketTypesIn.Respawn:
|
||||||
string? dimensionTypeNameRespawn = null;
|
string? dimensionTypeNameRespawn = null;
|
||||||
|
|
@ -1104,7 +1151,11 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
if (hasIcon)
|
if (hasIcon)
|
||||||
iconBase64 = dataTypes.ReadNextString(packetData);
|
iconBase64 = dataTypes.ReadNextString(packetData);
|
||||||
|
|
||||||
bool previewsChat = dataTypes.ReadNextBool(packetData);
|
|
||||||
|
bool previewsChat = false;
|
||||||
|
|
||||||
|
if (protocolVersion < MC_1_19_3_Version)
|
||||||
|
dataTypes.ReadNextBool(packetData);
|
||||||
|
|
||||||
handler.OnServerDataRecived(hasMotd, motd, hasIcon, iconBase64, previewsChat);
|
handler.OnServerDataRecived(hasMotd, motd, hasIcon, iconBase64, previewsChat);
|
||||||
break;
|
break;
|
||||||
|
|
@ -1134,25 +1185,22 @@ namespace MinecraftClient.Protocol.Handlers
|
||||||
case PacketTypesIn.SetDisplayChatPreview:
|
case PacketTypesIn.SetDisplayChatPreview:
|
||||||
bool previewsChatSetting = dataTypes.ReadNextBool(packetData);
|
bool previewsChatSetting = dataTypes.ReadNextBool(packetData);
|
||||||
handler.OnChatPreviewSettingUpdate(previewsChatSetting);
|
handler.OnChatPreviewSettingUpdate(previewsChatSetting);
|
||||||
break;
|
|
||||||
case PacketTypesIn.ChatPreview:
|
|
||||||
int queryID = dataTypes.ReadNextInt(packetData);
|
|
||||||
bool componentIsPresent = dataTypes.ReadNextBool(packetData);
|
|
||||||
|
|
||||||
// Currently noy implemented
|
|
||||||
log.Debug("New chat preview: ");
|
|
||||||
log.Debug(">> Query ID: " + queryID);
|
|
||||||
log.Debug(">> Component is present: " + componentIsPresent);
|
|
||||||
if (componentIsPresent)
|
|
||||||
{
|
|
||||||
string message = dataTypes.ReadNextString(packetData);
|
|
||||||
log.Debug(">> Component: " + ChatParser.ParseText(message));
|
|
||||||
//handler.OnTextReceived(message, true);
|
|
||||||
}
|
|
||||||
|
|
||||||
break;
|
break;
|
||||||
case PacketTypesIn.ChatSuggestions:
|
case PacketTypesIn.ChatSuggestions:
|
||||||
break;
|
break;
|
||||||
|
case PacketTypesIn.ProfilelessChatMessage:
|
||||||
|
string message_ = dataTypes.ReadNextString(packetData);
|
||||||
|
int messageType_ = dataTypes.ReadNextVarInt(packetData);
|
||||||
|
string messageName = dataTypes.ReadNextString(packetData);
|
||||||
|
bool hasTargetName = dataTypes.ReadNextBool(packetData);
|
||||||
|
|
||||||
|
string? targetName_ = null;
|
||||||
|
|
||||||
|
if (hasTargetName)
|
||||||
|
targetName_ = dataTypes.ReadNextString(packetData);
|
||||||
|
|
||||||
|
// Not clear for what this is used as the time of writting
|
||||||
|
break;
|
||||||
case PacketTypesIn.MapChunkBulk:
|
case PacketTypesIn.MapChunkBulk:
|
||||||
if (protocolVersion < MC_1_9_Version && handler.GetTerrainEnabled())
|
if (protocolVersion < MC_1_9_Version && handler.GetTerrainEnabled())
|
||||||
{
|
{
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue