mirror of
https://github.com/matrix-construct/construct
synced 2025-01-14 16:46:50 +01:00
ircd::net: Fix asio error code casting for SSL codes.
This commit is contained in:
parent
0ef29fc433
commit
6b961711cb
2 changed files with 15 additions and 17 deletions
|
@ -270,12 +270,10 @@ catch(const boost::system::system_error &e)
|
|||
using boost::asio::error::get_ssl_category;
|
||||
using boost::asio::error::get_misc_category;
|
||||
|
||||
const auto ec
|
||||
{
|
||||
e.code()
|
||||
};
|
||||
const error_code &ec{e.code()};
|
||||
const int &value{ec.value()};
|
||||
|
||||
if(ec.category() == get_system_category()) switch(ec.value())
|
||||
if(ec.category() == get_system_category()) switch(value)
|
||||
{
|
||||
case success:
|
||||
assert(0);
|
||||
|
@ -297,18 +295,18 @@ catch(const boost::system::system_error &e)
|
|||
default:
|
||||
break;
|
||||
}
|
||||
else if(ec.category() == get_misc_category()) switch(ec.value())
|
||||
else if(ec.category() == get_ssl_category()) switch(uint8_t(value))
|
||||
{
|
||||
case boost::asio::error::eof:
|
||||
case SSL_R_SHORT_READ:
|
||||
disconnect(*this, net::dc::RST);
|
||||
return false;
|
||||
|
||||
default:
|
||||
break;
|
||||
}
|
||||
else if(ec.category() == get_ssl_category()) switch(ec.value())
|
||||
else if(ec.category() == get_misc_category()) switch(value)
|
||||
{
|
||||
case SSL_R_SHORT_READ:
|
||||
case boost::asio::error::eof:
|
||||
disconnect(*this, net::dc::RST);
|
||||
return false;
|
||||
|
||||
|
@ -319,7 +317,7 @@ catch(const boost::system::system_error &e)
|
|||
log::error("client(%p): (unexpected) %s: (%d) %s",
|
||||
(const void *)this,
|
||||
ec.category().name(),
|
||||
int{ec.value()},
|
||||
value,
|
||||
ec.message());
|
||||
|
||||
disconnect(*this, net::dc::RST);
|
||||
|
|
14
ircd/net.cc
14
ircd/net.cc
|
@ -1271,20 +1271,20 @@ ircd::net::socket::handle_error(const error_code &ec)
|
|||
default:
|
||||
return true;
|
||||
}
|
||||
else if(ec.category() == get_misc_category()) switch(ec.value())
|
||||
else if(ec.category() == get_ssl_category()) switch(uint8_t(ec.value()))
|
||||
{
|
||||
// This indicates the remote closed the socket, we still
|
||||
// pass this up to the user so they can know that too.
|
||||
case boost::asio::error::eof:
|
||||
// Docs say this means we read less bytes off the socket than desired.
|
||||
case SSL_R_SHORT_READ:
|
||||
return true;
|
||||
|
||||
default:
|
||||
return true;
|
||||
}
|
||||
else if(ec.category() == get_ssl_category()) switch(ec.value())
|
||||
else if(ec.category() == get_misc_category()) switch(ec.value())
|
||||
{
|
||||
// Docs say this means we read less bytes off the socket than desired.
|
||||
case SSL_R_SHORT_READ:
|
||||
// This indicates the remote closed the socket, we still
|
||||
// pass this up to the user so they can know that too.
|
||||
case boost::asio::error::eof:
|
||||
return true;
|
||||
|
||||
default:
|
||||
|
|
Loading…
Reference in a new issue