2018-01-19 06:55:48 -08:00
|
|
|
// Matrix Construct
|
|
|
|
//
|
|
|
|
// Copyright (C) Matrix Construct Developers, Authors & Contributors
|
|
|
|
// Copyright (C) 2016-2018 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.
|
|
|
|
|
2018-02-03 18:22:01 -08:00
|
|
|
#pragma once
|
|
|
|
#define HAVE_IRCD_NET_ACCEPTOR_H
|
|
|
|
|
2018-01-19 06:55:48 -08:00
|
|
|
// This file is not included with the IRCd standard include stack because
|
|
|
|
// it requires symbols we can't forward declare without boost headers. It
|
|
|
|
// is part of the <ircd/asio.h> stack which can be included in your
|
|
|
|
// definition file if you need low level access to this acceptor API.
|
|
|
|
|
2019-06-01 15:01:19 -07:00
|
|
|
/// Implementation to net::listener. See listener.h for additional interface.
|
2022-06-14 14:15:53 -07:00
|
|
|
struct [[gnu::visibility("protected")]]
|
|
|
|
ircd::net::acceptor
|
2019-03-10 13:48:06 -07:00
|
|
|
:std::enable_shared_from_this<struct ircd::net::acceptor>
|
2018-01-19 06:55:48 -08:00
|
|
|
{
|
|
|
|
using error_code = boost::system::error_code;
|
2019-03-10 13:48:06 -07:00
|
|
|
using callback = listener::callback;
|
|
|
|
using proffer = listener::proffer;
|
2019-06-01 13:54:55 -07:00
|
|
|
using sockets = std::list<std::shared_ptr<socket>>;
|
2018-01-19 06:55:48 -08:00
|
|
|
|
2019-03-13 12:04:21 -07:00
|
|
|
IRCD_EXCEPTION(listener::error, error)
|
2019-03-13 12:05:57 -07:00
|
|
|
IRCD_EXCEPTION(error, sni_warning)
|
2019-03-13 12:04:21 -07:00
|
|
|
|
2018-01-19 06:55:48 -08:00
|
|
|
static log::log log;
|
2020-12-17 20:27:44 -08:00
|
|
|
static ios::descriptor accept_desc;
|
|
|
|
static ios::descriptor handshake_desc;
|
2019-06-01 13:54:55 -07:00
|
|
|
static conf::item<size_t> handshaking_max;
|
|
|
|
static conf::item<size_t> handshaking_max_per_peer;
|
2018-03-09 12:22:10 -08:00
|
|
|
static conf::item<milliseconds> timeout;
|
2019-04-15 19:54:31 -07:00
|
|
|
static conf::item<std::string> ssl_curve_list;
|
2019-03-12 17:27:56 -07:00
|
|
|
static conf::item<std::string> ssl_cipher_list;
|
2019-03-12 17:47:57 -07:00
|
|
|
static conf::item<std::string> ssl_cipher_blacklist;
|
2018-01-19 06:55:48 -08:00
|
|
|
|
2019-03-10 13:48:06 -07:00
|
|
|
net::listener *listener_;
|
2018-01-19 06:55:48 -08:00
|
|
|
std::string name;
|
2018-08-29 15:50:55 -07:00
|
|
|
std::string opts;
|
2019-09-30 13:24:50 -07:00
|
|
|
std::string cname;
|
2018-01-19 06:55:48 -08:00
|
|
|
size_t backlog;
|
2018-07-06 18:38:08 -07:00
|
|
|
listener::callback cb;
|
2018-09-01 22:00:38 -07:00
|
|
|
listener::proffer pcb;
|
2022-07-07 22:07:59 -07:00
|
|
|
bpf::prog filter;
|
2018-01-19 06:55:48 -08:00
|
|
|
asio::ssl::context ssl;
|
|
|
|
ip::tcp::endpoint ep;
|
|
|
|
ip::tcp::acceptor a;
|
2019-06-01 15:31:38 -07:00
|
|
|
size_t accepting {0};
|
2019-06-01 13:54:55 -07:00
|
|
|
sockets handshaking;
|
2018-01-19 06:55:48 -08:00
|
|
|
bool interrupting {false};
|
|
|
|
ctx::dock joining;
|
|
|
|
|
2019-09-30 12:55:53 -07:00
|
|
|
// Internal configuration
|
|
|
|
void configure_dh(const json::object &);
|
|
|
|
void configure_certs(const json::object &);
|
|
|
|
void configure_curves(const json::object &);
|
|
|
|
void configure_ciphers(const json::object &);
|
|
|
|
void configure_flags(const json::object &);
|
|
|
|
void configure_password(const json::object &);
|
2018-01-19 06:55:48 -08:00
|
|
|
void configure(const json::object &opts);
|
|
|
|
|
|
|
|
// Handshake stack
|
2020-05-30 22:27:53 -07:00
|
|
|
bool handle_sni(socket &, int &ad);
|
|
|
|
string_view handle_alpn(socket &, const vector_view<const string_view> &in);
|
2020-03-03 14:12:28 -08:00
|
|
|
void check_handshake_error(const error_code &ec, socket &) const;
|
2019-06-01 13:54:55 -07:00
|
|
|
void handshake(const error_code &, const std::shared_ptr<socket>, const decltype(handshaking)::const_iterator) noexcept;
|
2018-01-19 06:55:48 -08:00
|
|
|
|
|
|
|
// Acceptance stack
|
2020-03-03 13:54:14 -08:00
|
|
|
static bool proffer_default(listener &, const ipport &);
|
2020-03-03 14:12:28 -08:00
|
|
|
bool check_handshake_limit(socket &, const ipport &) const;
|
|
|
|
bool check_accept_error(const error_code &ec, socket &) const;
|
2019-06-01 15:31:38 -07:00
|
|
|
void accept(const error_code &, const std::shared_ptr<socket>) noexcept;
|
2018-01-19 06:55:48 -08:00
|
|
|
|
|
|
|
// Accept next
|
2019-01-18 09:42:44 -08:00
|
|
|
bool set_handle();
|
2018-01-19 06:55:48 -08:00
|
|
|
|
|
|
|
// Acceptor shutdown
|
|
|
|
bool interrupt() noexcept;
|
|
|
|
void join() noexcept;
|
2019-03-16 15:32:58 -07:00
|
|
|
void close();
|
|
|
|
void open();
|
2018-01-19 06:55:48 -08:00
|
|
|
|
2019-01-18 09:42:44 -08:00
|
|
|
acceptor(net::listener &,
|
|
|
|
const string_view &name,
|
2018-07-06 18:38:08 -07:00
|
|
|
const json::object &opts,
|
2018-09-01 22:00:38 -07:00
|
|
|
listener::callback,
|
|
|
|
listener::proffer);
|
2018-07-06 18:38:08 -07:00
|
|
|
|
2018-01-19 06:55:48 -08:00
|
|
|
~acceptor() noexcept;
|
|
|
|
};
|