From 8bbc512fe58d36ba1c89ec0160cf3390f25e4cc1 Mon Sep 17 00:00:00 2001 From: Ciaran Gultnieks Date: Mon, 23 May 2011 20:40:25 +0100 Subject: [PATCH] Added 'shout' player privilege --- src/player.cpp | 4 ++++ src/player.h | 19 ++++++++++++------- src/server.cpp | 32 +++++++++++++++++++------------- 3 files changed, 35 insertions(+), 20 deletions(-) diff --git a/src/player.cpp b/src/player.cpp index 12f18de7..147b6c97 100644 --- a/src/player.cpp +++ b/src/player.cpp @@ -36,6 +36,8 @@ std::wstring privsToString(u64 privs) os<privs; + if(g_settings.get("name") == player->getName()) + privs = PRIV_ALL; + // Parse commands std::wstring commandprefix = L"/#"; if(message.substr(0, commandprefix.size()) == commandprefix) @@ -2916,12 +2922,6 @@ void Server::ProcessData(u8 *data, u32 datasize, u16 peer_id) message = message.substr(commandprefix.size()); - // Local player gets all privileges regardless of - // what's set on their account. - u64 privs = player->privs; - if(g_settings.get("name") == player->getName()) - privs = PRIV_ALL; - ServerCommandContext *ctx = new ServerCommandContext( str_split(message, L' '), this, @@ -2937,13 +2937,19 @@ void Server::ProcessData(u8 *data, u32 datasize, u16 peer_id) } else { - line += L"<"; - /*if(is_operator) - line += L"@";*/ - line += name; - line += L"> "; - line += message; - send_to_others = true; + if(privs & PRIV_SHOUT) + { + line += L"<"; + line += name; + line += L"> "; + line += message; + send_to_others = true; + } + else + { + line += L"Server: You are not allowed to shout"; + send_to_sender = true; + } } if(line != L"")