Use size when parsing received buffers into strings in NetworkServer

This commit is contained in:
Adam Honse 2023-10-01 22:43:32 -05:00
parent af53230244
commit d7ed55b264

View file

@ -266,7 +266,7 @@ void NetworkServer::StartServer()
for(res = result; res && socket_count < MAXSOCK; res = res->ai_next) for(res = result; res && socket_count < MAXSOCK; res = res->ai_next)
{ {
server_sock[socket_count] = socket(res->ai_family, res->ai_socktype, res->ai_protocol); server_sock[socket_count] = socket(res->ai_family, res->ai_socktype, res->ai_protocol);
if(server_sock[socket_count] == INVALID_SOCKET) if(server_sock[socket_count] == INVALID_SOCKET)
{ {
printf("Error: network socket could not be created\n"); printf("Error: network socket could not be created\n");
@ -320,7 +320,7 @@ void NetworkServer::StartServer()
freeaddrinfo(result); freeaddrinfo(result);
server_online = true; server_online = true;
/*-------------------------------------------------*\ /*-------------------------------------------------*\
| Start the connection thread | | Start the connection thread |
\*-------------------------------------------------*/ \*-------------------------------------------------*/
@ -430,7 +430,7 @@ void NetworkServer::ConnectionThreadFunction(int socket_idx)
socklen_t len; socklen_t len;
len = sizeof(tmp_addr); len = sizeof(tmp_addr);
getpeername(client_info->client_sock, (struct sockaddr*)&tmp_addr, &len); getpeername(client_info->client_sock, (struct sockaddr*)&tmp_addr, &len);
if(tmp_addr.ss_family == AF_INET) if(tmp_addr.ss_family == AF_INET)
{ {
struct sockaddr_in *s_4 = (struct sockaddr_in *)&tmp_addr; struct sockaddr_in *s_4 = (struct sockaddr_in *)&tmp_addr;
@ -780,7 +780,10 @@ void NetworkServer::ListenThreadFunction(NetworkClientInfo * client_info)
if(profile_manager) if(profile_manager)
{ {
profile_manager->SaveProfile(data); std::string profile_name;
profile_name.assign(data, header.pkt_size);
profile_manager->SaveProfile(profile_name);
} }
break; break;
@ -793,7 +796,10 @@ void NetworkServer::ListenThreadFunction(NetworkClientInfo * client_info)
if(profile_manager) if(profile_manager)
{ {
profile_manager->LoadProfile(data); std::string profile_name;
profile_name.assign(data, header.pkt_size);
profile_manager->LoadProfile(profile_name);
} }
for(RGBController* controller : controllers) for(RGBController* controller : controllers)
@ -811,7 +817,10 @@ void NetworkServer::ListenThreadFunction(NetworkClientInfo * client_info)
if(profile_manager) if(profile_manager)
{ {
profile_manager->DeleteProfile(data); std::string profile_name;
profile_name.assign(data, header.pkt_size);
profile_manager->DeleteProfile(profile_name);
} }
break; break;
@ -897,14 +906,14 @@ void NetworkServer::ProcessRequest_ClientProtocolVersion(SOCKET client_sock, uns
ClientInfoChanged(); ClientInfoChanged();
} }
void NetworkServer::ProcessRequest_ClientString(SOCKET client_sock, unsigned int /*data_size*/, char * data) void NetworkServer::ProcessRequest_ClientString(SOCKET client_sock, unsigned int data_size, char * data)
{ {
ServerClientsMutex.lock(); ServerClientsMutex.lock();
for(unsigned int this_idx = 0; this_idx < ServerClients.size(); this_idx++) for(unsigned int this_idx = 0; this_idx < ServerClients.size(); this_idx++)
{ {
if(ServerClients[this_idx]->client_sock == client_sock) if(ServerClients[this_idx]->client_sock == client_sock)
{ {
ServerClients[this_idx]->client_string = data; ServerClients[this_idx]->client_string.assign(data, data_size);
break; break;
} }
} }
@ -1028,7 +1037,7 @@ void NetworkServer::SendReply_PluginList(SOCKET client_sock)
{ {
unsigned int data_size = 0; unsigned int data_size = 0;
unsigned int data_ptr = 0; unsigned int data_ptr = 0;
/*---------------------------------------------------------*\ /*---------------------------------------------------------*\
| Calculate data size | | Calculate data size |
\*---------------------------------------------------------*/ \*---------------------------------------------------------*/
@ -1045,12 +1054,12 @@ void NetworkServer::SendReply_PluginList(SOCKET client_sock)
data_size += strlen(plugins[i].version.c_str()) + 1; data_size += strlen(plugins[i].version.c_str()) + 1;
data_size += sizeof(unsigned int) * 2; data_size += sizeof(unsigned int) * 2;
} }
/*---------------------------------------------------------*\ /*---------------------------------------------------------*\
| Create data buffer | | Create data buffer |
\*---------------------------------------------------------*/ \*---------------------------------------------------------*/
unsigned char *data_buf = new unsigned char[data_size]; unsigned char *data_buf = new unsigned char[data_size];
/*---------------------------------------------------------*\ /*---------------------------------------------------------*\
| Copy in data size | | Copy in data size |
\*---------------------------------------------------------*/ \*---------------------------------------------------------*/
@ -1103,14 +1112,14 @@ void NetworkServer::SendReply_PluginList(SOCKET client_sock)
\*---------------------------------------------------------*/ \*---------------------------------------------------------*/
memcpy(&data_buf[data_ptr], &i, sizeof(unsigned int)); memcpy(&data_buf[data_ptr], &i, sizeof(unsigned int));
data_ptr += sizeof(unsigned int); data_ptr += sizeof(unsigned int);
/*---------------------------------------------------------*\ /*---------------------------------------------------------*\
| Copy in plugin sdk version (data) | | Copy in plugin sdk version (data) |
\*---------------------------------------------------------*/ \*---------------------------------------------------------*/
memcpy(&data_buf[data_ptr], &plugins[i].protocol_version, sizeof(int)); memcpy(&data_buf[data_ptr], &plugins[i].protocol_version, sizeof(int));
data_ptr += sizeof(int); data_ptr += sizeof(int);
} }
NetPacketHeader reply_hdr; NetPacketHeader reply_hdr;
unsigned int reply_size; unsigned int reply_size;