From 6a33a72c7b423afb143a67a3e88d27e4bcafd116 Mon Sep 17 00:00:00 2001 From: auth Date: Sun, 5 Jul 2020 12:00:04 +0200 Subject: More assembler implementations. Small changes to client on server. --- server/src/client/client.h | 15 +++++++++------ server/src/main.cpp | 7 +------ server/src/server/server.cpp | 11 +++++++---- 3 files changed, 17 insertions(+), 16 deletions(-) (limited to 'server/src') diff --git a/server/src/client/client.h b/server/src/client/client.h index 4dad02e..141ac67 100644 --- a/server/src/client/client.h +++ b/server/src/client/client.h @@ -15,7 +15,6 @@ class client { public: std::string hwid; - client() : m_socket{-1} {}; client(const int& socket, const std::string_view ip) : m_socket{std::move(socket)}, m_ip{ip}, m_ssl{nullptr} {} @@ -27,6 +26,8 @@ class client { close(m_socket); SSL_shutdown(m_ssl); SSL_free(m_ssl); + + m_socket = -1; } void reset() { std::time(&m_time); } @@ -46,12 +47,12 @@ class client { int stream(std::vector& data, float* dur = nullptr); int read_stream(std::vector& out); - int stream(std::string &str) { + int stream(std::string& str) { std::vector vec(str.begin(), str.end()); return stream(vec); } - int read_stream(std::string &str) { + int read_stream(std::string& str) { std::vector out; int ret = read_stream(out); str.assign(out.begin(), out.end()); @@ -60,8 +61,10 @@ class client { void gen_session(); - int &get_socket() { return m_socket; } - auto &get_ip() { return m_ip; } - auto &get_session() { return m_session_id; } + int& get_socket() { return m_socket; } + auto& get_ip() { return m_ip; } + auto& get_session() { return m_session_id; } + + operator bool() const { return m_ssl && m_socket > 0; } }; }; // namespace tcp \ No newline at end of file diff --git a/server/src/main.cpp b/server/src/main.cpp index 77269a9..e7e0253 100644 --- a/server/src/main.cpp +++ b/server/src/main.cpp @@ -26,12 +26,6 @@ int main(int argc, char* argv[]) { }); client_server.disconnect_event.add([&](tcp::client& client) { - auto it = std::find_if(client_server().begin(), - client_server().end(), [&](tcp::client& c) { - return client.get_socket() == c.get_socket(); - }); - - client_server().erase(it); client.cleanup(); io::logger->info("{} disconnected", client.get_ip()); @@ -67,6 +61,7 @@ int main(int argc, char* argv[]) { }); client_server.timeout_event.add([&](tcp::client& client) { + client.cleanup(); io::logger->info("{} timed out.", client.get_ip()); }); diff --git a/server/src/server/server.cpp b/server/src/server/server.cpp index 5996eb3..b7f7606 100644 --- a/server/src/server/server.cpp +++ b/server/src/server/server.cpp @@ -57,7 +57,13 @@ tcp::select_status tcp::server::peek() { int maxfd = m_socket; - for (auto& c : client_stack) { + for (int i = 0; i < client_stack.size(); i++) { + auto c = client_stack[i]; + if(!c) { + client_stack.erase(client_stack.begin() + i); + continue; + } + const int s = c.get_socket(); FD_SET(s, &m_server_set); @@ -144,9 +150,6 @@ void tcp::server::check_timeout() { if (it != client_stack.end()) { timeout_event.call(*it); - - it->cleanup(); - client_stack.erase(it); } } -- cgit v1.2.3