1
0
mirror of https://github.com/vcmi/vcmi.git synced 2025-11-23 22:37:55 +02:00
Files
vcmi/lib/network/NetworkHandler.cpp

100 lines
2.8 KiB
C++
Raw Normal View History

2024-01-12 01:10:41 +02:00
/*
* NetworkHandler.cpp, part of VCMI engine
*
* Authors: listed in file AUTHORS in main folder
*
* License: GNU General Public License v2.0 or later
* Full text of license available in license.txt file, in main folder
*
*/
#include "StdInc.h"
#include "NetworkHandler.h"
#include "NetworkServer.h"
2024-01-12 16:55:36 +02:00
#include "NetworkConnection.h"
2024-01-12 01:10:41 +02:00
VCMI_LIB_NAMESPACE_BEGIN
std::unique_ptr<INetworkHandler> INetworkHandler::createHandler()
{
return std::make_unique<NetworkHandler>();
}
NetworkHandler::NetworkHandler()
2025-06-29 16:26:23 +03:00
: context(std::make_unique<NetworkContext>())
2024-01-12 01:10:41 +02:00
{}
std::unique_ptr<INetworkServer> NetworkHandler::createServerTCP(INetworkServerListener & listener)
{
2025-06-29 16:26:23 +03:00
return std::make_unique<NetworkServer>(listener, *context);
2025-06-28 21:42:54 +03:00
}
std::shared_ptr<INetworkConnection> NetworkHandler::createAsyncConnection(INetworkConnectionListener & listener)
{
2025-06-29 16:26:23 +03:00
auto loopbackConnection = std::make_shared<InternalConnection>(listener, *context);
2025-06-28 21:42:54 +03:00
loopbackConnection->connectTo(loopbackConnection);
return loopbackConnection;
2024-01-12 01:10:41 +02:00
}
2024-01-12 16:55:36 +02:00
void NetworkHandler::connectToRemote(INetworkClientListener & listener, const std::string & host, uint16_t port)
2024-01-12 01:10:41 +02:00
{
2025-06-29 16:26:23 +03:00
auto socket = std::make_shared<NetworkSocket>(*context);
auto resolver = std::make_shared<boost::asio::ip::tcp::resolver>(*context);
resolver->async_resolve(host, std::to_string(port),
2024-05-11 16:18:21 +00:00
[this, &listener, resolver, socket](const boost::system::error_code& error, const boost::asio::ip::tcp::resolver::results_type & endpoints)
2024-01-12 16:55:36 +02:00
{
if (error)
{
listener.onConnectionFailed(error.message());
return;
}
2024-05-11 16:18:21 +00:00
boost::asio::async_connect(*socket, endpoints, [this, socket, &listener](const boost::system::error_code& error, const boost::asio::ip::tcp::endpoint& endpoint)
{
if (error)
{
listener.onConnectionFailed(error.message());
return;
}
2025-06-29 16:26:23 +03:00
auto connection = std::make_shared<NetworkConnection>(listener, socket, *context);
connection->start();
listener.onConnectionEstablished(connection);
});
2024-01-12 16:55:36 +02:00
});
2024-01-12 01:10:41 +02:00
}
void NetworkHandler::run()
{
2025-06-29 16:26:23 +03:00
boost::asio::executor_work_guard<decltype(context->get_executor())> work{context->get_executor()};
context->run();
2024-01-12 01:10:41 +02:00
}
void NetworkHandler::createTimer(INetworkTimerListener & listener, std::chrono::milliseconds duration)
{
2025-06-29 16:26:23 +03:00
auto timer = std::make_shared<NetworkTimer>(*context, duration);
2024-01-12 01:10:41 +02:00
timer->async_wait([&listener, timer](const boost::system::error_code& error){
if (!error)
listener.onTimer();
});
}
void NetworkHandler::createInternalConnection(INetworkClientListener & listener, INetworkServer & server)
{
2025-06-29 16:26:23 +03:00
auto localConnection = std::make_shared<InternalConnection>(listener, *context);
server.receiveInternalConnection(localConnection);
2025-06-29 16:26:23 +03:00
boost::asio::post(*context, [&listener, localConnection](){
listener.onConnectionEstablished(localConnection);
});
}
2024-01-12 01:10:41 +02:00
void NetworkHandler::stop()
{
2025-06-29 16:26:23 +03:00
context->stop();
2024-01-12 01:10:41 +02:00
}
VCMI_LIB_NAMESPACE_END