0
0
Fork 0
mirror of https://github.com/matrix-construct/construct synced 2025-01-01 10:24:13 +01:00

ircd::net: Improve loghead(acceptor) and loghead(acceptor_udp) related.

This commit is contained in:
Jason Volk 2019-05-31 02:35:22 -07:00
parent 2e525df668
commit 3e43a10e6d
3 changed files with 87 additions and 48 deletions

View file

@ -16,9 +16,6 @@ namespace ircd::net
struct listener;
struct acceptor;
std::ostream &operator<<(std::ostream &s, const listener &);
std::ostream &operator<<(std::ostream &s, const acceptor &);
extern conf::item<bool> listen;
std::string cipher_list(const acceptor &);
@ -26,6 +23,10 @@ namespace ircd::net
string_view name(const acceptor &);
ipport binder(const acceptor &);
ipport local(const acceptor &);
string_view loghead(const mutable_buffer &, const acceptor &);
string_view loghead(const acceptor &);
std::ostream &operator<<(std::ostream &s, const acceptor &);
std::ostream &operator<<(std::ostream &s, const listener &);
bool allow(acceptor &);
bool start(acceptor &);

View file

@ -16,6 +16,8 @@ namespace ircd::net
struct listener_udp;
struct acceptor_udp;
string_view loghead(const mutable_buffer &, const acceptor_udp &);
string_view loghead(const acceptor_udp &);
std::ostream &operator<<(std::ostream &s, const listener_udp &);
std::ostream &operator<<(std::ostream &s, const acceptor_udp &);
}

View file

@ -1287,11 +1287,6 @@ const
// net/acceptor.h
//
namespace ircd::net
{
thread_local char logheadbuf[512];
}
//
// acceptor
//
@ -1360,6 +1355,34 @@ ircd::net::allow(acceptor &a)
return true;
}
std::ostream &
ircd::net::operator<<(std::ostream &s, const acceptor &a)
{
s << loghead(a);
return s;
}
ircd::string_view
ircd::net::loghead(const acceptor &a)
{
thread_local char buf[512];
return loghead(buf, a);
}
ircd::string_view
ircd::net::loghead(const mutable_buffer &out,
const acceptor &a)
{
thread_local char addrbuf[128];
return fmt::sprintf
{
out, "'%s' @ [%s]:%u",
name(a),
string(addrbuf, a.ep.address()),
a.ep.port(),
};
}
ircd::net::ipport
ircd::net::local(const acceptor &a)
{
@ -1384,14 +1407,6 @@ ircd::net::config(const acceptor &a)
return a.opts;
}
std::ostream &
ircd::net::operator<<(std::ostream &s, const acceptor &a)
{
thread_local char addrbuf[128];
s << "'" << a.name << "' @ [" << string(addrbuf, a.ep.address()) << "]:" << a.ep.port();
return s;
}
//
// acceptor::acceptor
//
@ -1446,7 +1461,7 @@ try
log::debug
{
log, "%s configured listener SSL", string(logheadbuf, *this)
log, "%s configured listener SSL", loghead(*this)
};
open();
@ -1491,20 +1506,20 @@ ircd::net::acceptor::open()
a.non_blocking(true);
log::debug
{
log, "%s opened listener socket", string(logheadbuf, *this)
log, "%s opened listener socket", loghead(*this)
};
a.bind(ep);
log::debug
{
log, "%s bound listener socket", string(logheadbuf, *this)
log, "%s bound listener socket", loghead(*this)
};
a.listen(backlog);
log::debug
{
log, "%s listening (backlog: %lu, max connections: %zu)",
string(logheadbuf, *this),
loghead(*this),
backlog,
max_connections
};
@ -1522,7 +1537,7 @@ ircd::net::acceptor::close()
join();
log::debug
{
log, "%s listener finished", string(logheadbuf, *this)
log, "%s listener finished", loghead(*this)
};
}
@ -1610,7 +1625,7 @@ catch(const std::exception &e)
{
throw panic
{
"%s: %s", string(logheadbuf, *this), e.what()
"%s: %s", loghead(*this), e.what()
};
}
@ -1637,7 +1652,7 @@ noexcept try
log::debug
{
log, "%s: accepted(%zu) %s %s",
string(logheadbuf, *this),
loghead(*this),
accepting,
loghead(*sock),
string(ecbuf, ec)
@ -1681,7 +1696,7 @@ catch(const ctx::interrupted &e)
log::debug
{
log, "%s: acceptor interrupted %s %s",
string(logheadbuf, *this),
loghead(*this),
loghead(*sock),
string(ecbuf, ec)
};
@ -1697,7 +1712,7 @@ catch(const std::system_error &e)
log::derror
{
log, "%s: %s in accept(): %s",
string(logheadbuf, *this),
loghead(*this),
loghead(*sock),
e.what()
};
@ -1713,7 +1728,7 @@ catch(const std::exception &e)
log::error
{
log, "%s: %s in accept(): %s",
string(logheadbuf, *this),
loghead(*this),
loghead(*sock),
e.what()
};
@ -1801,7 +1816,7 @@ catch(const ctx::interrupted &e)
log::debug
{
log, "%s: SSL handshake interrupted %s %s",
string(logheadbuf, *this),
loghead(*this),
loghead(*sock),
string(ecbuf, ec)
};
@ -1815,7 +1830,7 @@ catch(const std::system_error &e)
log::derror
{
log, "%s: %s in handshake(): %s",
string(logheadbuf, *this),
loghead(*this),
loghead(*sock),
e.what()
};
@ -1829,7 +1844,7 @@ catch(const std::exception &e)
log::error
{
log, "%s: %s in handshake(): %s",
string(logheadbuf, *this),
loghead(*this),
loghead(*sock),
e.what()
};
@ -1880,7 +1895,7 @@ ircd::net::acceptor::handle_alpn(SSL &ssl,
log::debug
{
log, "%s offered %zu ALPN protocols",
string(logheadbuf, *this),
loghead(*this),
size(in),
};
@ -1890,7 +1905,7 @@ ircd::net::acceptor::handle_alpn(SSL &ssl,
log::debug
{
log, "%s ALPN protocol %zu of %zu: '%s'",
string(logheadbuf, *this),
loghead(*this),
i,
size(in),
in[i],
@ -1984,7 +1999,7 @@ try
log::debug
{
log, "%s offered SNI '%s'",
string(logheadbuf, *this),
loghead(*this),
name
};
@ -1995,7 +2010,7 @@ catch(const sni_warning &e)
log::warning
{
log, "%s during SNI :%s",
string(logheadbuf, *this),
loghead(*this),
e.what()
};
@ -2006,7 +2021,7 @@ catch(const std::exception &e)
log::error
{
log, "%s during SNI :%s",
string(logheadbuf, *this),
loghead(*this),
e.what()
};
@ -2058,7 +2073,7 @@ ircd::net::acceptor::configure(const json::object &opts)
{
log::debug
{
log, "%s preparing listener socket configuration...", string(logheadbuf, *this)
log, "%s preparing listener socket configuration...", loghead(*this)
};
ulong flags(0);
@ -2151,7 +2166,7 @@ ircd::net::acceptor::configure(const json::object &opts)
throw error
{
"%s: SSL certificate chain file @ `%s' not found",
string(logheadbuf, *this),
loghead(*this),
filename
};
@ -2159,7 +2174,7 @@ ircd::net::acceptor::configure(const json::object &opts)
log::info
{
log, "%s using certificate chain file '%s'",
string(logheadbuf, *this),
loghead(*this),
filename
};
}
@ -2175,7 +2190,7 @@ ircd::net::acceptor::configure(const json::object &opts)
throw error
{
"%s: SSL certificate pem file @ `%s' not found",
string(logheadbuf, *this),
loghead(*this),
filename
};
@ -2183,7 +2198,7 @@ ircd::net::acceptor::configure(const json::object &opts)
log::info
{
log, "%s using certificate file '%s'",
string(logheadbuf, *this),
loghead(*this),
filename
};
}
@ -2199,7 +2214,7 @@ ircd::net::acceptor::configure(const json::object &opts)
throw error
{
"%s: SSL private key file @ `%s' not found",
string(logheadbuf, *this),
loghead(*this),
filename
};
@ -2207,7 +2222,7 @@ ircd::net::acceptor::configure(const json::object &opts)
log::info
{
log, "%s using private key file '%s'",
string(logheadbuf, *this),
loghead(*this),
filename
};
}
@ -2223,7 +2238,7 @@ ircd::net::acceptor::configure(const json::object &opts)
throw error
{
"%s: SSL tmp dh file @ `%s' not found",
string(logheadbuf, *this),
loghead(*this),
filename
};
@ -2231,7 +2246,7 @@ ircd::net::acceptor::configure(const json::object &opts)
log::info
{
log, "%s using tmp dh file '%s'",
string(logheadbuf, *this),
loghead(*this),
filename
};
}
@ -2246,7 +2261,7 @@ ircd::net::acceptor::configure(const json::object &opts)
log::info
{
log, "%s using DH params supplied in options (%zu bytes)",
string(logheadbuf, *this),
loghead(*this),
size(buf)
};
}
@ -2263,7 +2278,7 @@ ircd::net::acceptor::configure(const json::object &opts)
log::notice
{
log, "%s asking for password with purpose '%s' (size: %zu)",
string(logheadbuf, *this),
loghead(*this),
purpose,
size
};
@ -2285,10 +2300,31 @@ ircd::net::acceptor::configure(const json::object &opts)
std::ostream &
ircd::net::operator<<(std::ostream &s, const acceptor_udp &a)
{
s << "'" << a.name << "' @ [" << string(a.ep.address()) << "]:" << a.ep.port();
s << loghead(a);
return s;
}
ircd::string_view
ircd::net::loghead(const acceptor_udp &a)
{
thread_local char buf[512];
return loghead(buf, a);
}
ircd::string_view
ircd::net::loghead(const mutable_buffer &out,
const acceptor_udp &a)
{
thread_local char addrbuf[128];
return fmt::sprintf
{
out, "'%s' @ [%s]:%u",
a.name,
string(addrbuf, a.ep.address()),
a.ep.port(),
};
}
//
// acceptor_udp::acceptor
//
@ -2323,13 +2359,13 @@ try
a.set_option(reuse_address);
log::debug
{
log, "%s opened listener socket", string(logheadbuf, *this)
log, "%s opened listener socket", loghead(*this)
};
a.bind(ep);
log::debug
{
log, "%s bound listener socket", string(logheadbuf, *this)
log, "%s bound listener socket", loghead(*this)
};
}
catch(const boost::system::system_error &e)