0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-14 16:46:50 +01:00

ircd: Develop various server.

This commit is contained in:
Jason Volk 2017-11-25 14:17:22 -07:00
parent 5e9a82af86
commit 532f416a3d
2 changed files with 61 additions and 3 deletions

View file

@ -84,6 +84,10 @@ struct ircd::server::link
std::deque<server *> q;
enum state state;
bool connected() const noexcept;
bool connect(const net::remote &);
bool disconnect();
link(const net::remote &remote);
};

View file

@ -91,12 +91,27 @@ catch(const boost::system::system_error &e)
{
using namespace boost::system::errc;
log::error("read error: %s: %s",
log::error("read error: %s: %s: %s",
string(server.n->remote),
e.code().category().name(),
e.what());
if(ircd::runlevel == ircd::runlevel::QUIT)
throw;
switch(e.code().value())
{
case SSL_R_SHORT_READ:
case boost::asio::error::eof:
{
auto &link{*begin(server.n->links)};
link.disconnect();
if(!link.connect(server.n->remote))
throw;
return read(server, start, stop);
}
case operation_canceled:
throw http::error(http::REQUEST_TIMEOUT);
@ -121,12 +136,27 @@ catch(const boost::system::system_error &e)
{
using namespace boost::system::errc;
log::error("write error: %s: %s",
log::error("write error: %s: (%s #%d) %s",
string(server.n->remote),
e.code().category().name(),
e.code().value(),
e.what());
switch(e.code().value())
{
case SSL_R_SHORT_READ:
case boost::asio::error::eof:
case protocol_error:
case broken_pipe:
{
auto &link{*begin(server.n->links)};
link.disconnect();
if(!link.connect(server.n->remote))
throw;
return write(server, iov);
}
case operation_canceled:
throw http::error(http::REQUEST_TIMEOUT);
@ -216,7 +246,31 @@ ircd::server::node::del(const size_t &num)
//
ircd::server::link::link(const net::remote &remote)
:s{std::make_shared<net::socket>(remote)}
:s{std::make_shared<net::socket>()}
,state{state::DEAD}
{
connect(remote);
}
bool
ircd::server::link::disconnect()
{
return net::disconnect(*s);
}
bool
ircd::server::link::connect(const net::remote &remote)
{
if(connected())
return false;
s->connect(remote, 30000ms);
return true;
}
bool
ircd::server::link::connected()
const noexcept
{
return net::connected(*s);
}