Fix EAGAIN bug in ZMQ-RPC/ZMQ-PUB

dev-v0.11.2
Lee *!* Clagett 7 months ago
parent d9b765a3af
commit fe746dca4e

@ -158,13 +158,22 @@ void ZmqServer::serve()
if (!pub || sockets[2].revents) if (!pub || sockets[2].revents)
{ {
std::string message = MONERO_UNWRAP(net::zmq::receive(rep.get(), read_flags)); expect<std::string> message = net::zmq::receive(rep.get(), read_flags);
MDEBUG("Received RPC request: \"" << message << "\""); if (!message)
epee::byte_slice response = handler.handle(std::move(message)); {
// EAGAIN can occur when using `zmq_poll`, which doesn't inspect for message validity
const boost::string_ref response_view{reinterpret_cast<const char*>(response.data()), response.size()}; if (message != net::zmq::make_error_code(EAGAIN))
MDEBUG("Sending RPC reply: \"" << response_view << "\""); MONERO_THROW(message.error(), "Read failure on ZMQ-RPC");
MONERO_UNWRAP(net::zmq::send(std::move(response), rep.get())); }
else // no errors
{
MDEBUG("Received RPC request: \"" << *message << "\"");
epee::byte_slice response = handler.handle(std::move(*message));
const boost::string_ref response_view{reinterpret_cast<const char*>(response.data()), response.size()};
MDEBUG("Sending RPC reply: \"" << response_view << "\"");
MONERO_UNWRAP(net::zmq::send(std::move(response), rep.get()));
}
} }
} }
} }

Loading…
Cancel
Save