2018-02-04 03:22:01 +01:00
|
|
|
// Matrix Construct
|
|
|
|
//
|
2018-01-14 03:03:04 +01:00
|
|
|
// Copyright (C) Matrix Construct Developers, Authors & Contributors
|
2018-02-04 03:22:01 +01:00
|
|
|
// Copyright (C) 2016-2018 Jason Volk <jason@zemos.net>
|
2018-01-14 03:03:04 +01:00
|
|
|
//
|
|
|
|
// Permission to use, copy, modify, and/or distribute this software for any
|
|
|
|
// purpose with or without fee is hereby granted, provided that the above
|
2018-02-04 03:22:01 +01:00
|
|
|
// copyright notice and this permission notice is present in all copies. The
|
|
|
|
// full license for this software is available in the LICENSE file.
|
2018-01-14 03:03:04 +01:00
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#define HAVE_IRCD_SERVER_LINK_H
|
|
|
|
|
2019-04-22 20:47:29 +02:00
|
|
|
namespace ircd::server
|
|
|
|
{
|
|
|
|
string_view loghead(const mutable_buffer &out, const link &);
|
|
|
|
string_view loghead(const link &);
|
|
|
|
}
|
|
|
|
|
2018-03-05 15:59:10 +01:00
|
|
|
/// A single connection to a remote peer.
|
2018-01-14 03:03:04 +01:00
|
|
|
///
|
|
|
|
struct ircd::server::link
|
|
|
|
{
|
2018-03-04 06:54:42 +01:00
|
|
|
static conf::item<size_t> tag_max_default;
|
|
|
|
static conf::item<size_t> tag_commit_max_default;
|
2019-04-12 07:18:47 +02:00
|
|
|
static uint64_t ids;
|
2018-03-04 06:54:42 +01:00
|
|
|
|
2019-04-12 07:18:47 +02:00
|
|
|
uint64_t id {++ids}; ///< unique identifier of link.
|
2018-03-10 16:50:19 +01:00
|
|
|
server::peer *peer; ///< backreference to peer
|
2018-01-14 03:03:04 +01:00
|
|
|
std::shared_ptr<net::socket> socket; ///< link's socket
|
2018-01-17 06:23:15 +01:00
|
|
|
std::list<tag> queue; ///< link's work queue
|
2019-07-14 21:13:53 +02:00
|
|
|
time_t synack_ts {0L}; ///< time socket was estab
|
2019-09-07 04:55:44 +02:00
|
|
|
time_t read_ts {0L}; ///< time of last read
|
|
|
|
time_t write_ts {0L}; ///< time of last write
|
2018-03-09 16:29:37 +01:00
|
|
|
bool op_init {false}; ///< link is connecting
|
|
|
|
bool op_fini {false}; ///< link is disconnecting
|
2019-04-17 07:27:24 +02:00
|
|
|
bool op_open {false};
|
2018-03-09 16:29:37 +01:00
|
|
|
bool op_write {false}; ///< async operation state
|
|
|
|
bool op_read {false}; ///< async operation state
|
|
|
|
bool exclude {false}; ///< link is excluded
|
2018-01-14 03:03:04 +01:00
|
|
|
|
2018-01-16 03:04:23 +01:00
|
|
|
template<class F> size_t accumulate_tags(F&&) const;
|
2018-01-14 03:03:04 +01:00
|
|
|
|
2018-01-15 05:51:39 +01:00
|
|
|
void discard_read();
|
2018-03-20 22:07:52 +01:00
|
|
|
const_buffer read(const mutable_buffer &buf);
|
2018-01-15 09:11:32 +01:00
|
|
|
const_buffer process_read_next(const const_buffer &, tag &, bool &done);
|
2018-01-14 06:16:49 +01:00
|
|
|
bool process_read(const_buffer &);
|
2018-01-14 03:03:04 +01:00
|
|
|
void handle_readable_success();
|
2019-05-02 11:24:13 +02:00
|
|
|
void handle_readable(const error_code &) noexcept;
|
2018-01-14 03:03:04 +01:00
|
|
|
void wait_readable();
|
|
|
|
|
2018-01-15 09:11:32 +01:00
|
|
|
const_buffer process_write_next(const const_buffer &);
|
|
|
|
bool process_write(tag &);
|
|
|
|
void handle_writable_success();
|
2019-05-02 11:24:13 +02:00
|
|
|
void handle_writable(const error_code &) noexcept;
|
2018-01-14 06:16:49 +01:00
|
|
|
void wait_writable();
|
|
|
|
|
2018-01-14 03:03:04 +01:00
|
|
|
void handle_close(std::exception_ptr);
|
|
|
|
void handle_open(std::exception_ptr);
|
|
|
|
|
|
|
|
public:
|
2018-01-16 03:04:23 +01:00
|
|
|
// config related
|
|
|
|
size_t tag_max() const;
|
|
|
|
size_t tag_commit_max() const;
|
2018-01-14 03:03:04 +01:00
|
|
|
|
2018-01-16 03:04:23 +01:00
|
|
|
// indicator lights
|
2018-03-10 16:50:19 +01:00
|
|
|
bool finished() const;
|
2018-02-27 07:49:44 +01:00
|
|
|
bool opened() const noexcept;
|
2018-01-16 03:04:23 +01:00
|
|
|
bool ready() const;
|
|
|
|
bool busy() const;
|
|
|
|
|
|
|
|
// stats for upload-side bytes across all tags
|
2018-03-27 02:11:39 +02:00
|
|
|
size_t write_size() const;
|
2018-01-16 03:04:23 +01:00
|
|
|
size_t write_completed() const;
|
|
|
|
size_t write_remaining() const;
|
|
|
|
|
|
|
|
// stats for download-side bytes ~across all tags~; note: this is not
|
|
|
|
// accurate except for the one tag at the front of the queue having
|
|
|
|
// its response processed.
|
2018-03-27 02:11:39 +02:00
|
|
|
size_t read_size() const; // see: tag::read_total() notes
|
2018-01-16 03:04:23 +01:00
|
|
|
size_t read_completed() const; // see: tag::read_completed() notes
|
|
|
|
size_t read_remaining() const; // see: tag::read_remaining() notes
|
|
|
|
|
2018-03-27 02:21:24 +02:00
|
|
|
// stats accumulated
|
|
|
|
size_t write_total() const;
|
|
|
|
size_t read_total() const;
|
|
|
|
|
2018-01-16 03:04:23 +01:00
|
|
|
// stats for tags
|
2018-01-16 05:04:45 +01:00
|
|
|
size_t tag_count() const;
|
2018-01-16 03:04:23 +01:00
|
|
|
size_t tag_committed() const;
|
|
|
|
size_t tag_uncommitted() const;
|
|
|
|
|
|
|
|
// request panel
|
2018-03-04 06:55:59 +01:00
|
|
|
void cancel_uncommitted(std::exception_ptr);
|
|
|
|
void cancel_committed(std::exception_ptr);
|
|
|
|
void cancel_all(std::exception_ptr);
|
2019-09-07 05:01:53 +02:00
|
|
|
void cleanup_canceled();
|
2018-01-14 03:03:04 +01:00
|
|
|
void submit(request &);
|
|
|
|
|
2018-01-16 03:04:23 +01:00
|
|
|
// control panel
|
2018-01-16 06:13:48 +01:00
|
|
|
bool close(const net::close_opts & = net::close_opts_default);
|
2018-01-16 03:04:23 +01:00
|
|
|
bool open(const net::open_opts &);
|
|
|
|
|
2018-03-05 15:59:10 +01:00
|
|
|
link(server::peer &);
|
2018-05-02 20:29:13 +02:00
|
|
|
link(link &&) = delete;
|
|
|
|
link(const link &) = delete;
|
2018-01-14 03:03:04 +01:00
|
|
|
~link() noexcept;
|
|
|
|
};
|