udp_tracker() : m_udp_announces(0) , m_socket(m_ios) , m_port(0) , m_abort(false) { error_code ec; m_socket.open(udp::v4(), ec); if (ec) { std::printf("UDP Error opening listen UDP tracker socket: %s\n", ec.message().c_str()); return; } m_socket.bind(udp::endpoint(address_v4::any(), 0), ec); if (ec) { std::printf("UDP Error binding UDP tracker socket to port 0: %s\n", ec.message().c_str()); return; } m_port = m_socket.local_endpoint(ec).port(); if (ec) { std::printf("UDP Error getting local endpoint of UDP tracker socket: %s\n", ec.message().c_str()); return; } std::printf("%s: UDP tracker initialized on port %d\n", time_now_string(), m_port); m_thread = std::make_shared<std::thread>(&udp_tracker::thread_fun, this); }
dht_server() : m_dht_requests(0) , m_socket(m_ios) , m_port(0) { error_code ec; m_socket.open(udp::v4(), ec); if (ec) { std::printf("Error opening listen DHT socket: %s\n", ec.message().c_str()); return; } m_socket.bind(udp::endpoint(address_v4::any(), 0), ec); if (ec) { std::printf("Error binding DHT socket to port 0: %s\n", ec.message().c_str()); return; } m_port = m_socket.local_endpoint(ec).port(); if (ec) { std::printf("Error getting local endpoint of DHT socket: %s\n", ec.message().c_str()); return; } std::printf("%s: DHT initialized on port %d\n", time_now_string(), m_port); m_thread = std::make_shared<std::thread>(&dht_server::thread_fun, this); }
dht_server() : m_dht_requests(0) , m_socket(m_ios) , m_port(0) { error_code ec; m_socket.open(udp::v4(), ec); if (ec) { fprintf(stderr, "Error opening listen DHT socket: %s\n", ec.message().c_str()); return; } m_socket.bind(udp::endpoint(address_v4::any(), 0), ec); if (ec) { fprintf(stderr, "Error binding DHT socket to port 0: %s\n", ec.message().c_str()); return; } m_port = m_socket.local_endpoint(ec).port(); if (ec) { fprintf(stderr, "Error getting local endpoint of DHT socket: %s\n", ec.message().c_str()); return; } fprintf(stderr, "%s: DHT initialized on port %d\n", time_now_string(), m_port); m_thread.reset(new libtorrent::thread(boost::bind(&dht_server::thread_fun, this))); }
udp_tracker() : m_udp_announces(0) , m_socket(m_ios) , m_port(0) { error_code ec; m_socket.open(udp::v4(), ec); if (ec) { fprintf(stderr, "UDP Error opening listen UDP tracker socket: %s\n", ec.message().c_str()); return; } m_socket.bind(udp::endpoint(address_v4::any(), 0), ec); if (ec) { fprintf(stderr, "UDP Error binding UDP tracker socket to port 0: %s\n", ec.message().c_str()); return; } m_port = m_socket.local_endpoint(ec).port(); if (ec) { fprintf(stderr, "UDP Error getting local endpoint of UDP tracker socket: %s\n", ec.message().c_str()); return; } fprintf(stderr, "%s: UDP tracker initialized on port %d\n", time_now_string(), m_port); m_thread.reset(new thread(boost::bind(&udp_tracker::thread_fun, this))); }