diff --git a/DEV_INFO b/DEV_INFO index cc71118..eb5d275 100644 --- a/DEV_INFO +++ b/DEV_INFO @@ -1,4 +1,2 @@ id -1 is server / valid message if other parameters are valid as well -id -2 is invalid network message - -NetworkMessage: subject 1 is reserved for handshake validation \ No newline at end of file +id -2 is invalid network message \ No newline at end of file diff --git a/HLAPI/HLAPI/HLAPI.vcxproj b/HLAPI/HLAPI/HLAPI.vcxproj index 625e226..73d79f2 100644 --- a/HLAPI/HLAPI/HLAPI.vcxproj +++ b/HLAPI/HLAPI/HLAPI.vcxproj @@ -19,7 +19,7 @@ - + diff --git a/HLAPI/HLAPI/HLAPI.vcxproj.filters b/HLAPI/HLAPI/HLAPI.vcxproj.filters index 60bef89..037db0a 100644 --- a/HLAPI/HLAPI/HLAPI.vcxproj.filters +++ b/HLAPI/HLAPI/HLAPI.vcxproj.filters @@ -9,9 +9,6 @@ - - include - include @@ -45,6 +42,9 @@ include + + include + diff --git a/TODO b/TODO index 3c5137c..470d5c7 100644 --- a/TODO +++ b/TODO @@ -1,14 +1,11 @@ -initialization code for other operating systems - currently VoidNet only supports windows initialization code for tcp client and tcp server for other operating systems - currently windows only -revamped BitConverter class -new StringConverter class IPUtil class for other os's -maybe i should implement error codes and exceptions - plugin system - idk how im going to implement it yet maybe i should use virtual methods for the server and client, maybe... -TcpServer::SendMessage rework \ No newline at end of file +TcpConnectionHandler::AddClient max_connections + +Test udp stuff \ No newline at end of file diff --git a/VoidNetVS/VoidNetVS/VoidNetVS.vcxproj b/VoidNetVS/VoidNetVS/VoidNetVS.vcxproj index f54eb0a..6fc6191 100644 --- a/VoidNetVS/VoidNetVS/VoidNetVS.vcxproj +++ b/VoidNetVS/VoidNetVS/VoidNetVS.vcxproj @@ -49,7 +49,6 @@ - @@ -59,6 +58,7 @@ + {5172321E-CCB0-4A77-9F3D-FAAF0084F434} diff --git a/VoidNetVS/VoidNetVS/VoidNetVS.vcxproj.filters b/VoidNetVS/VoidNetVS/VoidNetVS.vcxproj.filters index a6f7b68..72f2d20 100644 --- a/VoidNetVS/VoidNetVS/VoidNetVS.vcxproj.filters +++ b/VoidNetVS/VoidNetVS/VoidNetVS.vcxproj.filters @@ -90,9 +90,6 @@ src\Http - - src\Http - src\Http @@ -123,5 +120,8 @@ src + + src + \ No newline at end of file diff --git a/include/HLAPI/BitConverter.hpp b/include/HLAPI/ByteConverter.hpp similarity index 83% rename from include/HLAPI/BitConverter.hpp rename to include/HLAPI/ByteConverter.hpp index 9984841..1957da2 100644 --- a/include/HLAPI/BitConverter.hpp +++ b/include/HLAPI/ByteConverter.hpp @@ -9,7 +9,7 @@ namespace std { - class BitConverter + class ByteConverter { public: template @@ -24,7 +24,7 @@ namespace std inline static T FromBytes(uint8_t *data) { if (!data) - throw std::invalid_argument("cant have null parameter -> BitConverter::FromBytes"); + throw std::invalid_argument("cant have null parameter -> ByteConverter::FromBytes"); T value; memcpy(&value, data, sizeof(T)); return value; diff --git a/include/HLAPI/NetworkMessage.hpp b/include/HLAPI/NetworkMessage.hpp index a4459da..7b91a6b 100644 --- a/include/HLAPI/NetworkMessage.hpp +++ b/include/HLAPI/NetworkMessage.hpp @@ -1,7 +1,7 @@ #pragma once #include "NetworkHeader.hpp" -#include "BitConverter.hpp" +#include "ByteConverter.hpp" #include #include @@ -68,9 +68,9 @@ namespace std::net uint8_t *bytes = new uint8_t[header.Size]; memcpy(bytes, &header, sizeOfNetHeader); - uint8_t *sender = BitConverter::ToBytes(m_senderID); // 4 - uint8_t *destination = BitConverter::ToBytes(m_destinationID); // 4 - uint8_t *tag = BitConverter::ToBytes(m_tag); // 4 + uint8_t *sender = ByteConverter::ToBytes(m_senderID); // 4 + uint8_t *destination = ByteConverter::ToBytes(m_destinationID); // 4 + uint8_t *tag = ByteConverter::ToBytes(m_tag); // 4 memcpy(bytes + sizeOfNetHeader, sender, 4); bytes[sizeOfNetHeader + 4] = (uint8_t)m_distributionMode; diff --git a/include/HLAPI/Server.hpp b/include/HLAPI/Server.hpp index fc644d0..9735cbc 100644 --- a/include/HLAPI/Server.hpp +++ b/include/HLAPI/Server.hpp @@ -20,7 +20,5 @@ namespace std::net private: std::shared_ptr m_tcpServer; - - std::shared_ptr m_queue; }; } \ No newline at end of file diff --git a/include/HLAPI/TcpConnectionHandler.hpp b/include/HLAPI/TcpConnectionHandler.hpp index aa666be..624179d 100644 --- a/include/HLAPI/TcpConnectionHandler.hpp +++ b/include/HLAPI/TcpConnectionHandler.hpp @@ -7,18 +7,12 @@ #include #include -//#include - namespace std::net { class MessageQueue; class TcpConnection; class Server; - - namespace sockets - { - class TcpListener; - } + class TcpListener; } namespace std::net @@ -49,7 +43,7 @@ namespace std::net std::vector> m_list; std::mutex m_listMutex; - uint32_t m_maxConnections; + uint32_t m_maxConnections = 0; std::thread m_receiveThread; std::thread m_sendThread; @@ -59,5 +53,7 @@ namespace std::net std::shared_ptr m_queue; std::shared_ptr m_listenerPtr; + + std::vector poll_fds; }; } \ No newline at end of file diff --git a/include/VoidNet/Net.hpp b/include/VoidNet/Net.hpp index e8822f3..8bc8e1c 100644 --- a/include/VoidNet/Net.hpp +++ b/include/VoidNet/Net.hpp @@ -24,16 +24,11 @@ #define SOCKET_ERROR -1 #define NO_ERROR 0 - #define INVALID_SOCKET NO_ERROR + #define INVALID_SOCKET NO_ERROR #define SOCKET int #define closesocket close - int closesocket(SOCKET soc) - { - return close(soc); - } - #endif #define DEFAULT_SERVER_PORT 61250 diff --git a/include/VoidNet/Response.hpp b/include/VoidNet/Response.hpp index 966e5e0..a7c6a20 100644 --- a/include/VoidNet/Response.hpp +++ b/include/VoidNet/Response.hpp @@ -21,7 +21,7 @@ namespace std::net return m_status; } - const std::string& daGetDatata() const + const std::string& GetData() const { return m_data; } diff --git a/include/VoidNet/TcpListener.hpp b/include/VoidNet/TcpListener.hpp index 40fc198..f586974 100644 --- a/include/VoidNet/TcpListener.hpp +++ b/include/VoidNet/TcpListener.hpp @@ -19,8 +19,8 @@ namespace std::net friend class std::net::TcpConnectionHandler; public: - TcpListener(uint16_t port, std::chrono::milliseconds inSleepTime = std::chrono::milliseconds(1)); - TcpListener(Socket *InSocket, std::chrono::milliseconds inSleepTime = std::chrono::milliseconds(1)); + TcpListener(uint16_t port, std::chrono::milliseconds inSleepTime = std::chrono::milliseconds(0)); + TcpListener(Socket *InSocket, std::chrono::milliseconds inSleepTime = std::chrono::milliseconds(0)); TcpClient *AcceptClient(); diff --git a/include/VoidNet/Util.hpp b/include/VoidNet/Util.hpp index df27cd5..cf710b2 100644 --- a/include/VoidNet/Util.hpp +++ b/include/VoidNet/Util.hpp @@ -7,31 +7,6 @@ namespace std::net { - inline static std::vector Split(const std::string &str, const std::string &delimiter) - { - std::vector splited; - if (str.empty() && delimiter.empty()) - return std::vector(); - std::string::size_type lastPos = str.find_first_not_of(delimiter, 0); - std::string::size_type pos = str.find_first_of(delimiter, lastPos); - - while (std::string::npos != pos || std::string::npos != lastPos) - { - splited.push_back(str.substr(lastPos, pos - lastPos)); - lastPos = str.find_first_not_of(delimiter, pos); - pos = str.find_first_of(delimiter, lastPos); - } - return splited; - } - - sockaddr_in CreateAddress(uint32_t address, uint16_t port) - { - sockaddr_in addr; - std::memset(&addr, 0, sizeof(addr)); - addr.sin_addr.s_addr = htonl(address); - addr.sin_family = AF_INET; - addr.sin_port = htons(port); - - return addr; - } + static std::vector Split(const std::string& str, const std::string& delimiter); + static sockaddr_in CreateAddress(uint32_t address, uint16_t port); } \ No newline at end of file diff --git a/src/HLAPI/NetworkMessage.cpp b/src/HLAPI/NetworkMessage.cpp index 42c968c..2132b3a 100644 --- a/src/HLAPI/NetworkMessage.cpp +++ b/src/HLAPI/NetworkMessage.cpp @@ -29,12 +29,12 @@ namespace std::net NetworkHeader header; header.Size = 13 + sizeOfNetHeader + m_dataSize; - uint8_t *bytes = new uint8_t[header.Size]; + uint8_t *bytes = new uint8_t[header.Size](); memcpy(bytes, &header, sizeOfNetHeader); - uint8_t *sender = BitConverter::ToBytes(m_senderID); // 4 - uint8_t *destination = BitConverter::ToBytes(m_destinationID); // 4 - uint8_t *tag = BitConverter::ToBytes(m_tag); // 4 + uint8_t *sender = ByteConverter::ToBytes(m_senderID); // 4 + uint8_t *destination = ByteConverter::ToBytes(m_destinationID); // 4 + uint8_t *tag = ByteConverter::ToBytes(m_tag); // 4 memcpy(bytes + sizeOfNetHeader, sender, 4); bytes[sizeOfNetHeader + 4] = (uint8_t)m_distributionMode; diff --git a/src/HLAPI/Server.cpp b/src/HLAPI/Server.cpp index 99d3888..99c901a 100644 --- a/src/HLAPI/Server.cpp +++ b/src/HLAPI/Server.cpp @@ -9,8 +9,6 @@ namespace std::net Server::Server(uint32_t max_connections, uint16_t port) { m_tcpServer = std::make_shared(max_connections, port); - m_queue = std::make_shared(); - //m_tcpServer->m_connectionHandler->m_queue = m_queue; } void Server::Start() diff --git a/src/HLAPI/TcpConnectionHandler.cpp b/src/HLAPI/TcpConnectionHandler.cpp index 52b7394..7d965b8 100644 --- a/src/HLAPI/TcpConnectionHandler.cpp +++ b/src/HLAPI/TcpConnectionHandler.cpp @@ -28,11 +28,17 @@ namespace std::net void TcpConnectionHandler::Start() { m_run.exchange(true); + + pollfd master_fd; + master_fd.fd = m_listenerPtr->m_socket->GetNativeSocket(); + master_fd.events = POLLRDNORM; + poll_fds.emplace_back(master_fd); + std::thread receive_thread(&TcpConnectionHandler::HandleReceiveMsgAndConnsThreaded, this); m_receiveThread.swap(receive_thread); - //std::thread send_thread(&TcpConnectionHandler::HandleSendThreaded, this); - //m_sendThread.swap(send_thread); + std::thread send_thread(&TcpConnectionHandler::HandleSendThreaded, this); + m_sendThread.swap(send_thread); } void TcpConnectionHandler::Stop() @@ -60,14 +66,9 @@ namespace std::net uint32_t *id_ptr = &id; - NetworkMessage msg(0, DistributionMode::ID, id, (uint32_t)InternalTags::AssignID, id_ptr, sizeof(id_ptr)); + NetworkMessage msg(-1, DistributionMode::ID, id, (uint32_t)InternalTags::AssignID, id_ptr, sizeof(id_ptr)); - std::this_thread::sleep_for(std::chrono::milliseconds(50)); - - uint32_t serialized_size; - uint8_t *serialized_data = msg.SerializeData(serialized_size); - int32_t sent; - if (!c->GetClient()->Send(serialized_data, serialized_size, sent)) + if (!c->sendMessage(msg)) { //couldnt send return; @@ -77,6 +78,11 @@ namespace std::net m_list.push_back(c); m_listMutex.unlock(); + pollfd client_fd; + client_fd.fd = c->m_client->m_socket->GetNativeSocket(); + client_fd.events = POLLRDNORM; + poll_fds.emplace_back(client_fd); + m_queue->EnqueueConnection(msg); } @@ -108,21 +114,6 @@ namespace std::net void TcpConnectionHandler::HandleReceiveMsgAndConns() { - // https://www.ibm.com/support/knowledgecenter/en/ssw_i5_54/rzab6/poll.htm - std::vector poll_fds; - pollfd master_fd; - master_fd.fd = m_listenerPtr->m_socket->GetNativeSocket(); - master_fd.events = POLLRDNORM; - poll_fds.emplace_back(master_fd); - - for (size_t i = 0; i < m_list.size(); i++) - { - pollfd client_fd; - client_fd.fd = m_list.at(i)->m_client->m_socket->GetNativeSocket(); - client_fd.events = POLLRDNORM; - poll_fds.emplace_back(client_fd); - } - int res = poll(poll_fds.data(), poll_fds.size(), -1); if (res < 0) @@ -138,13 +129,9 @@ namespace std::net for (int i = 0; i < poll_fds.size(); i++) { - if (poll_fds.at(i).revents == 0) + if (poll_fds.at(i).revents == 0 || poll_fds[i].revents != POLLRDNORM) continue; - if (poll_fds[i].revents != POLLRDNORM) - { - continue; - } if (poll_fds.at(i).fd == m_listenerPtr->m_socket->GetNativeSocket()) { TcpClient *c = m_listenerPtr->AcceptClient(); @@ -173,7 +160,12 @@ namespace std::net msg.Deserialize(buffer.get(), net_header->Size); if (msg.GetTag() == (uint32_t)InternalTags::Disconnect) + { + // i? or i+1 + poll_fds.erase(poll_fds.begin() + i); + m_queue->EnqueueDisconnection(msg); + } else if (msg.GetTag() == (uint32_t)InternalTags::Connect) m_queue->EnqueueConnection(msg); else @@ -191,9 +183,6 @@ namespace std::net { NetworkMessage msg = m_queue->DequeueMessageToSend(); - uint32_t size; - std::unique_ptr data(msg.SerializeData(size)); - if (msg.GetDistributionMode() == DistributionMode::Others) { m_listMutex.lock(); @@ -202,8 +191,7 @@ namespace std::net std::shared_ptr c = m_list.at(i); if (c->GetID() != msg.GetSenderID()) { - int32_t sent; - if (!c->GetClient()->Send(data.get(), size, sent)) + if (!c->sendMessage(msg)) { // it failed - retry? or just disconnect right in the first try } @@ -219,8 +207,7 @@ namespace std::net std::shared_ptr c = m_list.at(i); if (c->GetID() != msg.GetSenderID()) { - int32_t sent; - if (!c->GetClient()->Send(data.get(), size, sent)) + if (!c->sendMessage(msg)) { // it failed - retry? or just disconnect right in the first try } @@ -238,8 +225,7 @@ namespace std::net std::shared_ptr c = m_list.at(i); if (c->GetID() == msg.GetSenderID()) { - int32_t sent; - if (!c->GetClient()->Send(data.get(), size, sent)) + if (!c->sendMessage(msg)) { // it failed - retry? or just disconnect right in the first try } @@ -254,8 +240,7 @@ namespace std::net { std::shared_ptr c = m_list.at(i); - int32_t sent; - if (!c->GetClient()->Send(data.get(), size, sent)) + if (!c->sendMessage(msg)) { // it failed - retry? or just disconnect right in the first try } @@ -268,9 +253,8 @@ namespace std::net for (int i = 0; i < m_list.size(); i++) { std::shared_ptr c = m_list.at(i); - - int32_t sent; - if (!c->GetClient()->Send(data.get(), size, sent)) + + if (!c->sendMessage(msg)) { // it failed - retry? or just disconnect right in the first try } @@ -289,18 +273,12 @@ namespace std::net void TcpConnectionHandler::HandleReceiveMsgAndConnsThreaded() { while (m_run.load()) - { HandleReceiveMsgAndConns(); - std::this_thread::sleep_for(std::chrono::milliseconds(5)); - } } void TcpConnectionHandler::HandleSendThreaded() { while (m_run.load()) - { HandleSend(); - std::this_thread::sleep_for(std::chrono::milliseconds(5)); - } } } \ No newline at end of file diff --git a/src/HLAPI/main.cpp b/src/HLAPI/main.cpp index ac90fc3..192f298 100644 --- a/src/HLAPI/main.cpp +++ b/src/HLAPI/main.cpp @@ -1,6 +1,6 @@ #include "Init.hpp" #include "Server.hpp" -#include "BitConverter.hpp" +#include "ByteConverter.hpp" #include "TcpClient.hpp" #include "InternalTags.hpp" #include "NetworkMessage.hpp" @@ -34,7 +34,7 @@ int main() message.Deserialize(bytes, data_size); - uint32_t id = std::BitConverter::FromBytes((uint8_t*)(message.GetData())); + uint32_t id = std::ByteConverter::FromBytes((uint8_t*)(message.GetData())); if (message.GetTag() == (uint32_t)InternalTags::AssignID) std::cout << id << std::endl; } @@ -50,7 +50,7 @@ int main() message2.Deserialize(bytes2, data_size); - uint32_t id2 = std::BitConverter::FromBytes((uint8_t*)(message2.GetData())); + uint32_t id2 = std::ByteConverter::FromBytes((uint8_t*)(message2.GetData())); if (message2.GetTag() == (uint32_t)InternalTags::AssignID) std::cout << id2 << std::endl; } diff --git a/src/VoidNet/Parse.cpp b/src/VoidNet/Parse.cpp deleted file mode 100644 index e69de29..0000000 diff --git a/src/VoidNet/Socket.cpp b/src/VoidNet/Socket.cpp index 838ad30..2d6e1d8 100644 --- a/src/VoidNet/Socket.cpp +++ b/src/VoidNet/Socket.cpp @@ -194,8 +194,8 @@ namespace std::net { if (std::chrono::system_clock::now().time_since_epoch().count() - m_lastActivityTime > std::chrono::milliseconds(5).count()) { - SocketReturn writeState = HasState(SocketParam::CanWrite, std::chrono::milliseconds(1)); - SocketReturn readState = HasState(SocketParam::CanRead, std::chrono::milliseconds(1)); + SocketReturn writeState = HasState(SocketParam::CanWrite); + SocketReturn readState = HasState(SocketParam::CanRead); if (writeState == SocketReturn::Yes || readState == SocketReturn::Yes) { @@ -311,7 +311,7 @@ namespace std::net sockaddr_in addr; socklen_t size = sizeof(sockaddr_in); if (getsockname(m_socket, (sockaddr*)&addr, &size) != 0) - return 0; // invalid port + throw std::runtime_error("Invalid port"); return ntohs(addr.sin_port); } diff --git a/src/VoidNet/TcpListener.cpp b/src/VoidNet/TcpListener.cpp index 869ad0a..f49c9af 100644 --- a/src/VoidNet/TcpListener.cpp +++ b/src/VoidNet/TcpListener.cpp @@ -43,8 +43,6 @@ namespace std::net return new TcpClient(connectionSocket.release()); } } - else if (hasZeroSleepTime) - std::this_thread::sleep_for(std::chrono::milliseconds(0)); } else std::this_thread::sleep_for(std::chrono::milliseconds(m_sleepTime)); diff --git a/src/VoidNet/Uri.cpp b/src/VoidNet/Uri.cpp index df19bf7..6d8e88d 100644 --- a/src/VoidNet/Uri.cpp +++ b/src/VoidNet/Uri.cpp @@ -75,7 +75,7 @@ namespace std::net return result; } - static ParseResult parseAuthority(char const* str) + static ParseResult ParseAuthority(char const* str) { ParseResult result { @@ -99,7 +99,7 @@ namespace std::net return result; } - static ParseResult parsePath(char const* str) + static ParseResult ParsePath(char const* str) { // Return query/frag as part of path for now ParseResult result = ParseWhile(str, [](char ch) @@ -121,8 +121,8 @@ namespace std::net Uri uri; auto scheme = ParseScheme(str); - auto authority = parseAuthority(scheme.ch); - auto path = parsePath(authority.ch); + auto authority = ParseAuthority(scheme.ch); + auto path = ParsePath(authority.ch); uri.SetScheme(scheme.value); uri.SetAuthority(authority.value); diff --git a/src/VoidNet/Util.cpp b/src/VoidNet/Util.cpp new file mode 100644 index 0000000..d0a8c6f --- /dev/null +++ b/src/VoidNet/Util.cpp @@ -0,0 +1,29 @@ +#include "Util.hpp" + +std::vector std::net::Split(const std::string& str, const std::string& delimiter) +{ + std::vector splited; + if (str.empty() && delimiter.empty()) + return std::vector(); + std::string::size_type lastPos = str.find_first_not_of(delimiter, 0); + std::string::size_type pos = str.find_first_of(delimiter, lastPos); + + while (std::string::npos != pos || std::string::npos != lastPos) + { + splited.push_back(str.substr(lastPos, pos - lastPos)); + lastPos = str.find_first_not_of(delimiter, pos); + pos = str.find_first_of(delimiter, lastPos); + } + return splited; +} + +sockaddr_in std::net::CreateAddress(uint32_t address, uint16_t port) +{ + sockaddr_in addr; + std::memset(&addr, 0, sizeof(addr)); + addr.sin_addr.s_addr = htonl(address); + addr.sin_family = AF_INET; + addr.sin_port = htons(port); + + return addr; +}