From ced67342892213ab2b876ecae6750b80f61085fa Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Nicol=C3=A1s=20Barrios?= Date: Sat, 14 Sep 2024 21:25:16 -0300 Subject: [PATCH] Censor 'login' command in chat history (solves #2518) Censors /login command in chatbox history. This will also stop loging anything said using `/bind chatbox login` --- Client/core/CChat.cpp | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) diff --git a/Client/core/CChat.cpp b/Client/core/CChat.cpp index 438ea577fe..1fc53d406f 100644 --- a/Client/core/CChat.cpp +++ b/Client/core/CChat.cpp @@ -650,7 +650,28 @@ bool CChat::CharacterKeyHandler(CGUIKeyEventArgs KeyboardArgs) // If the input isn't empty and isn't identical to the previous entry in history, add it to the history if (!m_strInputText.empty() && (m_pInputHistory->Empty() || m_pInputHistory->GetLast() != m_strInputText)) - m_pInputHistory->Add(m_strInputText); + { + if (m_strCommand.empty() && m_strInputText[0] != '/') + { + // If the input is not a command, store it + m_pInputHistory->Add(m_strInputText); + } + else if (m_strCommand.compare("login") != 0) + { + // If the input is a command, check that it isn't the 'login' command, if it is censor it + char szInput[256]; + strncpy(szInput, m_strInputText.c_str() + 1, 256); + + const char* szCommand; + if (szInput[0]) + szCommand = strtok(szInput, " "); + + if ((strcmp(szCommand, "login") != 0)) + m_pInputHistory->Add(m_strInputText); + else if ((m_pInputHistory->Empty() || m_pInputHistory->GetLast() != std::string("/login"))) + m_pInputHistory->Add("/login"); + } + } SetInputVisible(false);