NetworkServer.cpp 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263
  1. /*
  2. * NetworkServer.cpp, part of VCMI engine
  3. *
  4. * Authors: listed in file AUTHORS in main folder
  5. *
  6. * License: GNU General Public License v2.0 or later
  7. * Full text of license available in license.txt file, in main folder
  8. *
  9. */
  10. #include "StdInc.h"
  11. #include "NetworkServer.h"
  12. #include "NetworkConnection.h"
  13. VCMI_LIB_NAMESPACE_BEGIN
  14. void NetworkServer::start(uint16_t port)
  15. {
  16. io = std::make_shared<boost::asio::io_service>();
  17. acceptor = std::make_shared<NetworkAcceptor>(*io, boost::asio::ip::tcp::endpoint(boost::asio::ip::tcp::v4(), port));
  18. startAsyncAccept();
  19. }
  20. void NetworkServer::startAsyncAccept()
  21. {
  22. std::shared_ptr<NetworkSocket> upcomingConnection = std::make_shared<NetworkSocket>(*io);
  23. acceptor->async_accept(*upcomingConnection, std::bind(&NetworkServer::connectionAccepted, this, upcomingConnection, _1));
  24. }
  25. void NetworkServer::run()
  26. {
  27. io->run();
  28. }
  29. void NetworkServer::connectionAccepted(std::shared_ptr<NetworkSocket> upcomingConnection, const boost::system::error_code & ec)
  30. {
  31. if(ec)
  32. {
  33. logNetwork->info("Something wrong during accepting: %s", ec.message());
  34. return;
  35. }
  36. try
  37. {
  38. logNetwork->info("We got a new connection! :)");
  39. auto connection = std::make_shared<NetworkConnection>(upcomingConnection);
  40. connections.insert(connection);
  41. connection->start();
  42. }
  43. catch(std::exception & e)
  44. {
  45. logNetwork->error("Failure processing new connection! %s", e.what());
  46. }
  47. startAsyncAccept();
  48. }
  49. void NetworkServer::sendPacket(const std::shared_ptr<NetworkConnection> & connection, const std::vector<uint8_t> & message)
  50. {
  51. connection->sendPacket(message);
  52. }
  53. VCMI_LIB_NAMESPACE_END