mirror of
https://github.com/vcmi/vcmi.git
synced 2025-06-21 00:19:29 +02:00
Implemented connection handling
This commit is contained in:
@ -12,8 +12,9 @@
|
||||
|
||||
VCMI_LIB_NAMESPACE_BEGIN
|
||||
|
||||
NetworkConnection::NetworkConnection(const std::shared_ptr<NetworkSocket> & socket)
|
||||
NetworkConnection::NetworkConnection(const std::shared_ptr<NetworkSocket> & socket, INetworkConnectionListener & listener)
|
||||
: socket(socket)
|
||||
, listener(listener)
|
||||
{
|
||||
|
||||
}
|
||||
@ -28,7 +29,13 @@ void NetworkConnection::start()
|
||||
|
||||
void NetworkConnection::onHeaderReceived(const boost::system::error_code & ec)
|
||||
{
|
||||
uint32_t messageSize = readPacketSize(ec);
|
||||
if (ec)
|
||||
{
|
||||
listener.onDisconnected(shared_from_this());
|
||||
return;
|
||||
}
|
||||
|
||||
uint32_t messageSize = readPacketSize();
|
||||
|
||||
boost::asio::async_read(*socket,
|
||||
readBuffer,
|
||||
@ -36,23 +43,15 @@ void NetworkConnection::onHeaderReceived(const boost::system::error_code & ec)
|
||||
std::bind(&NetworkConnection::onPacketReceived,this, _1, messageSize));
|
||||
}
|
||||
|
||||
uint32_t NetworkConnection::readPacketSize(const boost::system::error_code & ec)
|
||||
uint32_t NetworkConnection::readPacketSize()
|
||||
{
|
||||
if (ec)
|
||||
{
|
||||
throw std::runtime_error("Connection aborted!");
|
||||
}
|
||||
|
||||
if (readBuffer.size() < messageHeaderSize)
|
||||
{
|
||||
throw std::runtime_error("Failed to read header!");
|
||||
}
|
||||
|
||||
std::istream istream(&readBuffer);
|
||||
|
||||
uint32_t messageSize;
|
||||
istream.read(reinterpret_cast<char *>(&messageSize), messageHeaderSize);
|
||||
|
||||
if (messageSize > messageMaxSize)
|
||||
{
|
||||
throw std::runtime_error("Invalid packet size!");
|
||||
@ -65,7 +64,8 @@ void NetworkConnection::onPacketReceived(const boost::system::error_code & ec, u
|
||||
{
|
||||
if (ec)
|
||||
{
|
||||
throw std::runtime_error("Connection aborted!");
|
||||
listener.onDisconnected(shared_from_this());
|
||||
return;
|
||||
}
|
||||
|
||||
if (readBuffer.size() < expectedPacketSize)
|
||||
@ -79,6 +79,8 @@ void NetworkConnection::onPacketReceived(const boost::system::error_code & ec, u
|
||||
std::istream istream(&readBuffer);
|
||||
istream.read(reinterpret_cast<char *>(message.data()), messageHeaderSize);
|
||||
|
||||
listener.onPacketReceived(shared_from_this(), message);
|
||||
|
||||
start();
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user