2018-01-14 03:03:04 +01:00
|
|
|
// Copyright (C) Matrix Construct Developers, Authors & Contributors
|
|
|
|
// Copyright (C) 2016-2018 Jason Volk
|
|
|
|
//
|
|
|
|
// 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.
|
|
|
|
//
|
|
|
|
// THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
|
|
|
|
// IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
|
|
|
|
// WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
|
|
|
|
// DISCLAIMED. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
|
|
|
|
// INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
|
|
|
|
// (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
|
|
|
|
// SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
|
|
|
|
// HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
|
|
|
|
// STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
|
|
|
|
// IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
|
|
|
|
// POSSIBILITY OF SUCH DAMAGE.
|
|
|
|
|
|
|
|
#pragma once
|
|
|
|
#define HAVE_IRCD_SERVER_NODE_H
|
|
|
|
|
|
|
|
/// Remote entity.
|
|
|
|
///
|
|
|
|
struct ircd::server::node
|
|
|
|
:std::enable_shared_from_this<ircd::server::node>
|
|
|
|
{
|
|
|
|
net::remote remote;
|
2018-01-17 14:58:44 +01:00
|
|
|
std::exception_ptr eptr;
|
2018-01-14 03:03:04 +01:00
|
|
|
std::list<link> links;
|
2018-01-16 03:04:23 +01:00
|
|
|
|
|
|
|
template<class F> size_t accumulate_links(F&&) const;
|
|
|
|
template<class F> size_t accumulate_tags(F&&) const;
|
2018-01-14 03:03:04 +01:00
|
|
|
|
|
|
|
void handle_resolve(std::weak_ptr<node>, std::exception_ptr, const ipport &);
|
|
|
|
void resolve(const hostport &);
|
|
|
|
|
2018-01-16 13:01:26 +01:00
|
|
|
void disperse_uncommitted(link &);
|
2018-01-17 10:05:31 +01:00
|
|
|
void cancel_committed(link &, std::exception_ptr);
|
2018-01-16 13:01:26 +01:00
|
|
|
void disperse(link &);
|
2018-01-14 06:16:49 +01:00
|
|
|
void del(link &);
|
2018-01-16 09:45:51 +01:00
|
|
|
|
2018-01-16 06:13:48 +01:00
|
|
|
void handle_link_done(link &);
|
2018-01-16 05:04:45 +01:00
|
|
|
void handle_tag_done(link &, tag &) noexcept;
|
2018-01-23 20:38:38 +01:00
|
|
|
void handle_finished(link &);
|
2018-01-14 06:16:49 +01:00
|
|
|
void handle_error(link &, const boost::system::system_error &);
|
2018-01-17 10:05:31 +01:00
|
|
|
void handle_error(link &, std::exception_ptr);
|
2018-01-14 06:16:49 +01:00
|
|
|
void handle_close(link &, std::exception_ptr);
|
|
|
|
void handle_open(link &, std::exception_ptr);
|
|
|
|
|
2018-01-14 03:03:04 +01:00
|
|
|
public:
|
2018-01-16 03:04:23 +01:00
|
|
|
// config related
|
|
|
|
size_t link_max() const;
|
2018-01-16 06:13:48 +01:00
|
|
|
size_t link_min() const;
|
2018-01-16 03:04:23 +01:00
|
|
|
|
|
|
|
// stats for all links in node
|
2018-01-16 05:04:45 +01:00
|
|
|
size_t link_count() const;
|
2018-01-16 03:04:23 +01:00
|
|
|
size_t link_busy() const;
|
|
|
|
size_t link_ready() const;
|
|
|
|
|
|
|
|
// stats for all tags in all links in node
|
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;
|
|
|
|
|
|
|
|
// stats for all upload-side bytes in all tags in all links
|
|
|
|
size_t write_total() const;
|
|
|
|
size_t write_completed() const;
|
|
|
|
size_t write_remaining() const;
|
|
|
|
|
|
|
|
// stats for download-side bytes in all tags in all links (note:
|
|
|
|
// see notes in link.h/tag.h about inaccuracy here).
|
|
|
|
size_t read_total() const;
|
|
|
|
size_t read_completed() const;
|
|
|
|
size_t read_remaining() const;
|
2018-01-14 06:16:49 +01:00
|
|
|
|
2018-01-16 03:04:23 +01:00
|
|
|
// link control panel
|
2018-01-14 03:03:04 +01:00
|
|
|
link &link_add(const size_t &num = 1);
|
2018-01-16 13:01:26 +01:00
|
|
|
link *link_get(const request &);
|
2018-01-14 03:03:04 +01:00
|
|
|
|
2018-01-16 03:04:23 +01:00
|
|
|
// request panel
|
2018-01-14 03:03:04 +01:00
|
|
|
void submit(request &);
|
|
|
|
|
2018-01-16 03:04:23 +01:00
|
|
|
// control panel
|
2018-01-15 09:11:32 +01:00
|
|
|
void interrupt();
|
|
|
|
void close();
|
|
|
|
|
2018-01-14 03:03:04 +01:00
|
|
|
node();
|
|
|
|
~node() noexcept;
|
|
|
|
};
|