diff options
| author | oldmud0 <oldmud0@users.noreply.github.com> | 2018-07-04 10:53:31 -0400 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2018-07-04 10:53:31 -0400 |
| commit | e761805cd188337a5d5997dcf3389be9ee4316bd (patch) | |
| tree | 8acad75b402fc68fa50b526b2712c748e67b2d7e | |
| parent | f5e0177b9e13c68fa960dc873cd62452943dac3f (diff) | |
| parent | 0e15be73af266d5fbff3d83d731a7af2773ff532 (diff) | |
Merge pull request #19 from LeifaBot/master
Fix buffer overflow exploit
| -rw-r--r-- | networkmanager.cpp | 13 | ||||
| -rw-r--r-- | networkmanager.h | 3 |
2 files changed, 11 insertions, 5 deletions
diff --git a/networkmanager.cpp b/networkmanager.cpp index 8c0eaa7a..8afe087c 100644 --- a/networkmanager.cpp +++ b/networkmanager.cpp @@ -4,6 +4,7 @@ #include "debug_functions.h" #include "lobby.h" +#include <cstring> NetworkManager::NetworkManager(AOApplication *parent) : QObject(parent) { @@ -75,8 +76,9 @@ void NetworkManager::ship_server_packet(QString p_packet) void NetworkManager::handle_ms_packet() { - char buffer[16384] = {0}; - ms_socket->read(buffer, ms_socket->bytesAvailable()); + char buffer[buffer_max_size]; + std::memset(buffer, 0, buffer_max_size); + ms_socket->read(buffer, buffer_max_size); QString in_data = buffer; @@ -100,7 +102,7 @@ void NetworkManager::handle_ms_packet() QStringList packet_list = in_data.split("%", QString::SplitBehavior(QString::SkipEmptyParts)); for (QString packet : packet_list) - { + { AOPacket *f_packet = new AOPacket(packet); ao_app->ms_packet_received(f_packet); @@ -213,8 +215,9 @@ void NetworkManager::retry_ms_connect() void NetworkManager::handle_server_packet() { - char buffer[16384] = {0}; - server_socket->read(buffer, server_socket->bytesAvailable()); + char buffer[buffer_max_size]; + std::memset(buffer, 0, buffer_max_size); + server_socket->read(buffer, buffer_max_size); QString in_data = buffer; diff --git a/networkmanager.h b/networkmanager.h index 32aef733..ca47c402 100644 --- a/networkmanager.h +++ b/networkmanager.h @@ -48,6 +48,9 @@ public: const int ms_reconnect_delay_ms = 7000; + // kind of arbitrary max buffer size + const size_t buffer_max_size = 16384; + bool ms_partial_packet = false; QString ms_temp_packet = ""; |
