mirror of
https://github.com/matrix-construct/construct
synced 2024-11-29 02:02:38 +01:00
ircd::net: Split listeners/acceptors into unit.
This commit is contained in:
parent
93e878e8ba
commit
fa853580e1
4 changed files with 1559 additions and 1548 deletions
|
@ -160,6 +160,8 @@ libircd_la_SOURCES += net_addrs.cc
|
|||
libircd_la_SOURCES += net_dns.cc
|
||||
libircd_la_SOURCES += net_dns_cache.cc
|
||||
libircd_la_SOURCES += net_dns_resolver.cc
|
||||
libircd_la_SOURCES += net_listener.cc
|
||||
libircd_la_SOURCES += net_listener_udp.cc
|
||||
libircd_la_SOURCES += server.cc
|
||||
libircd_la_SOURCES += client.cc
|
||||
libircd_la_SOURCES += resource.cc
|
||||
|
@ -217,6 +219,8 @@ net.lo: AM_CPPFLAGS := ${ASIO_UNIT_CPPFLAGS} ${AM_CPPFLAGS}
|
|||
net_addrs.lo: AM_CPPFLAGS := ${ASIO_UNIT_CPPFLAGS} ${AM_CPPFLAGS}
|
||||
net_dns.lo: AM_CPPFLAGS := ${ASIO_UNIT_CPPFLAGS} ${AM_CPPFLAGS}
|
||||
net_dns_resolver.lo: AM_CPPFLAGS := ${ASIO_UNIT_CPPFLAGS} ${AM_CPPFLAGS}
|
||||
net_listener.lo: AM_CPPFLAGS := ${ASIO_UNIT_CPPFLAGS} ${AM_CPPFLAGS}
|
||||
net_listener_udp.lo: AM_CPPFLAGS := ${ASIO_UNIT_CPPFLAGS} ${AM_CPPFLAGS}
|
||||
openssl.lo: AM_CPPFLAGS := @SSL_CPPFLAGS@ @CRYPTO_CPPFLAGS@ ${AM_CPPFLAGS}
|
||||
parse.lo: AM_CPPFLAGS := ${SPIRIT_UNIT_CPPFLAGS} ${AM_CPPFLAGS}
|
||||
parse.lo: AM_CXXFLAGS := ${SPIRIT_UNIT_CXXFLAGS} ${AM_CXXFLAGS}
|
||||
|
|
1548
ircd/net.cc
1548
ircd/net.cc
File diff suppressed because it is too large
Load diff
1296
ircd/net_listener.cc
Normal file
1296
ircd/net_listener.cc
Normal file
File diff suppressed because it is too large
Load diff
259
ircd/net_listener_udp.cc
Normal file
259
ircd/net_listener_udp.cc
Normal file
|
@ -0,0 +1,259 @@
|
|||
// The Construct
|
||||
//
|
||||
// Copyright (C) The Construct Developers, Authors & Contributors
|
||||
// Copyright (C) 2016-2020 Jason Volk <jason@zemos.net>
|
||||
//
|
||||
// Permission to use, copy, modify, and/or distribute this software for any
|
||||
// purpose with or without fee is hereby granted, provided that the above
|
||||
// copyright notice and this permission notice is present in all copies. The
|
||||
// full license for this software is available in the LICENSE file.
|
||||
|
||||
std::ostream &
|
||||
ircd::net::operator<<(std::ostream &s, const listener_udp &a)
|
||||
{
|
||||
s << *a.acceptor;
|
||||
return s;
|
||||
}
|
||||
|
||||
std::ostream &
|
||||
ircd::net::operator<<(std::ostream &s, const acceptor_udp &a)
|
||||
{
|
||||
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(),
|
||||
};
|
||||
}
|
||||
|
||||
//
|
||||
// listener_udp::listener_udp
|
||||
//
|
||||
|
||||
ircd::net::listener_udp::listener_udp(const string_view &name,
|
||||
const std::string &opts)
|
||||
:listener_udp
|
||||
{
|
||||
name, json::object{opts}
|
||||
}
|
||||
{
|
||||
}
|
||||
|
||||
ircd::net::listener_udp::listener_udp(const string_view &name,
|
||||
const json::object &opts)
|
||||
:acceptor
|
||||
{
|
||||
std::make_unique<net::acceptor_udp>(name, opts)
|
||||
}
|
||||
{
|
||||
}
|
||||
|
||||
ircd::net::listener_udp::~listener_udp()
|
||||
noexcept
|
||||
{
|
||||
if(acceptor)
|
||||
acceptor->join();
|
||||
}
|
||||
|
||||
ircd::net::listener_udp::datagram &
|
||||
ircd::net::listener_udp::operator()(datagram &datagram)
|
||||
{
|
||||
assert(acceptor);
|
||||
return acceptor->operator()(datagram);
|
||||
}
|
||||
|
||||
ircd::string_view
|
||||
ircd::net::listener_udp::name()
|
||||
const
|
||||
{
|
||||
assert(acceptor);
|
||||
return acceptor->name;
|
||||
}
|
||||
|
||||
ircd::net::listener_udp::operator
|
||||
ircd::json::object()
|
||||
const
|
||||
{
|
||||
assert(acceptor);
|
||||
return acceptor->opts;
|
||||
}
|
||||
|
||||
//
|
||||
// acceptor_udp::acceptor
|
||||
//
|
||||
|
||||
ircd::net::acceptor_udp::acceptor_udp(const string_view &name,
|
||||
const json::object &opts)
|
||||
try
|
||||
:name
|
||||
{
|
||||
name
|
||||
}
|
||||
,opts
|
||||
{
|
||||
opts
|
||||
}
|
||||
,ep
|
||||
{
|
||||
make_address(unquote(opts.get("host", "*"_sv))),
|
||||
opts.at<uint16_t>("port")
|
||||
}
|
||||
,a
|
||||
{
|
||||
ios::get()
|
||||
}
|
||||
{
|
||||
static const ip::udp::socket::reuse_address reuse_address
|
||||
{
|
||||
true
|
||||
};
|
||||
|
||||
a.open(ep.protocol());
|
||||
a.set_option(reuse_address);
|
||||
log::debug
|
||||
{
|
||||
log, "%s opened listener socket", loghead(*this)
|
||||
};
|
||||
|
||||
a.bind(ep);
|
||||
log::debug
|
||||
{
|
||||
log, "%s bound listener socket", loghead(*this)
|
||||
};
|
||||
}
|
||||
catch(const boost::system::system_error &e)
|
||||
{
|
||||
throw_system_error(e);
|
||||
}
|
||||
|
||||
ircd::net::acceptor_udp::~acceptor_udp()
|
||||
noexcept
|
||||
{
|
||||
}
|
||||
|
||||
void
|
||||
ircd::net::acceptor_udp::join()
|
||||
noexcept try
|
||||
{
|
||||
interrupt();
|
||||
joining.wait([this]
|
||||
{
|
||||
return waiting == 0;
|
||||
});
|
||||
}
|
||||
catch(const std::exception &e)
|
||||
{
|
||||
log::error
|
||||
{
|
||||
log, "acceptor(%p) join :%s", this, e.what()
|
||||
};
|
||||
}
|
||||
|
||||
bool
|
||||
ircd::net::acceptor_udp::interrupt()
|
||||
noexcept try
|
||||
{
|
||||
a.cancel();
|
||||
return true;
|
||||
}
|
||||
catch(const boost::system::system_error &e)
|
||||
{
|
||||
log::error
|
||||
{
|
||||
log, "acceptor(%p) interrupt :%s", this, string(e)
|
||||
};
|
||||
|
||||
return false;
|
||||
}
|
||||
|
||||
ircd::net::listener_udp::datagram &
|
||||
ircd::net::acceptor_udp::operator()(datagram &datagram)
|
||||
{
|
||||
assert(ctx::current);
|
||||
|
||||
const auto flags
|
||||
{
|
||||
this->flags(datagram.flag)
|
||||
};
|
||||
|
||||
const auto interruption{[this]
|
||||
(ctx::ctx *const &)
|
||||
{
|
||||
this->interrupt();
|
||||
}};
|
||||
|
||||
const scope_count waiting
|
||||
{
|
||||
this->waiting
|
||||
};
|
||||
|
||||
ip::udp::endpoint ep;
|
||||
size_t rlen; continuation
|
||||
{
|
||||
continuation::asio_predicate, interruption, [this, &rlen, &datagram, &ep, &flags]
|
||||
(auto &yield)
|
||||
{
|
||||
rlen = a.async_receive_from(datagram.mbufs, ep, flags, yield);
|
||||
}
|
||||
};
|
||||
|
||||
datagram.remote = make_ipport(ep);
|
||||
datagram.mbuf = {data(datagram.mbuf), rlen};
|
||||
return datagram;
|
||||
}
|
||||
|
||||
boost::asio::ip::udp::socket::message_flags
|
||||
ircd::net::acceptor_udp::flags(const flag &flag)
|
||||
{
|
||||
ip::udp::socket::message_flags ret{0};
|
||||
|
||||
if(flag & flag::PEEK)
|
||||
ret |= ip::udp::socket::message_peek;
|
||||
|
||||
return ret;
|
||||
}
|
||||
|
||||
//
|
||||
// listener_udp::datagram
|
||||
//
|
||||
|
||||
ircd::net::listener_udp::datagram::datagram(const const_buffer &buf,
|
||||
const ipport &remote,
|
||||
const enum flag &flag)
|
||||
:remote{remote}
|
||||
,flag{flag}
|
||||
{
|
||||
cbuf = buf;
|
||||
cbufs =
|
||||
{
|
||||
&this->cbuf, 1
|
||||
};
|
||||
}
|
||||
|
||||
ircd::net::listener_udp::datagram::datagram(const mutable_buffer &buf,
|
||||
const enum flag &flag)
|
||||
:flag{flag}
|
||||
{
|
||||
mbuf = buf;
|
||||
mbufs =
|
||||
{
|
||||
&this->mbuf, 1
|
||||
};
|
||||
}
|
Loading…
Reference in a new issue