2006-09-05 01:22:21 +02:00
|
|
|
/*
|
|
|
|
|
2012-10-02 05:16:33 +02:00
|
|
|
Copyright (c) 2006-2012, Arvid Norberg
|
2006-09-05 01:22:21 +02:00
|
|
|
All rights reserved.
|
|
|
|
|
|
|
|
Redistribution and use in source and binary forms, with or without
|
|
|
|
modification, are permitted provided that the following conditions
|
|
|
|
are met:
|
|
|
|
|
|
|
|
* Redistributions of source code must retain the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer.
|
|
|
|
* Redistributions in binary form must reproduce the above copyright
|
|
|
|
notice, this list of conditions and the following disclaimer in
|
|
|
|
the documentation and/or other materials provided with the distribution.
|
|
|
|
* Neither the name of the author nor the names of its
|
|
|
|
contributors may be used to endorse or promote products derived
|
|
|
|
from this software without specific prior written permission.
|
|
|
|
|
|
|
|
THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "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 COPYRIGHT OWNER OR CONTRIBUTORS 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.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
#ifndef TORRENT_SESSION_STATUS_HPP_INCLUDED
|
|
|
|
#define TORRENT_SESSION_STATUS_HPP_INCLUDED
|
|
|
|
|
2008-10-26 22:16:46 +01:00
|
|
|
#include "libtorrent/config.hpp"
|
|
|
|
#include "libtorrent/size_type.hpp"
|
2010-11-29 02:33:05 +01:00
|
|
|
#include <vector>
|
2006-09-05 01:22:21 +02:00
|
|
|
|
|
|
|
namespace libtorrent
|
|
|
|
{
|
|
|
|
|
2013-11-29 06:29:39 +01:00
|
|
|
// holds statistics about a current dht_lookup operation.
|
|
|
|
// a DHT lookup is the travesal of nodes, looking up a
|
|
|
|
// set of target nodes in the DHT for retrieving and possibly
|
|
|
|
// storing information in the DHT
|
|
|
|
struct TORRENT_EXPORT dht_lookup
|
2008-09-20 19:42:25 +02:00
|
|
|
{
|
2013-11-29 06:29:39 +01:00
|
|
|
// string literal indicating which kind of lookup this is
|
2008-09-20 19:42:25 +02:00
|
|
|
char const* type;
|
2013-11-29 06:29:39 +01:00
|
|
|
|
|
|
|
// the number of outstanding request to individual nodes
|
|
|
|
// this lookup has right now
|
2008-09-20 19:42:25 +02:00
|
|
|
int outstanding_requests;
|
2013-11-29 06:29:39 +01:00
|
|
|
|
|
|
|
// the total number of requests that have timed out so far
|
|
|
|
// for this lookup
|
2008-09-20 19:42:25 +02:00
|
|
|
int timeouts;
|
2013-11-29 06:29:39 +01:00
|
|
|
|
|
|
|
// the total number of responses we have received for this
|
|
|
|
// lookup so far for this lookup
|
2008-09-20 19:42:25 +02:00
|
|
|
int responses;
|
2013-11-29 06:29:39 +01:00
|
|
|
|
|
|
|
// the branch factor for this lookup. This is the number of
|
|
|
|
// nodes we keep outstanding requests to in parallel by default.
|
|
|
|
// when nodes time out we may increase this.
|
2008-09-20 19:42:25 +02:00
|
|
|
int branch_factor;
|
2013-11-29 06:29:39 +01:00
|
|
|
|
|
|
|
// the number of nodes left that could be queries for this
|
|
|
|
// lookup. Many of these are likely to be part of the trail
|
|
|
|
// while performing the lookup and would never end up actually
|
|
|
|
// being queried.
|
2009-10-09 04:34:25 +02:00
|
|
|
int nodes_left;
|
2013-11-29 06:29:39 +01:00
|
|
|
|
2010-12-12 04:17:08 +01:00
|
|
|
// the number of seconds ago the
|
|
|
|
// last message was sent that's still
|
|
|
|
// outstanding
|
|
|
|
int last_sent;
|
2013-11-29 06:29:39 +01:00
|
|
|
|
2010-12-12 04:17:08 +01:00
|
|
|
// the number of outstanding requests
|
|
|
|
// that have exceeded the short timeout
|
|
|
|
// and are considered timed out in the
|
|
|
|
// sense that they increased the branch
|
|
|
|
// factor
|
|
|
|
int first_timeout;
|
|
|
|
};
|
|
|
|
|
2013-11-29 06:29:39 +01:00
|
|
|
// holds dht routing table stats
|
|
|
|
struct TORRENT_EXPORT dht_routing_bucket
|
2010-12-12 04:17:08 +01:00
|
|
|
{
|
2013-11-29 06:29:39 +01:00
|
|
|
// the total number of nodes and replacement nodes
|
|
|
|
// in the routing table
|
2010-12-12 04:17:08 +01:00
|
|
|
int num_nodes;
|
|
|
|
int num_replacements;
|
2013-11-29 06:29:39 +01:00
|
|
|
|
2010-12-12 04:17:08 +01:00
|
|
|
// number of seconds since last activity
|
|
|
|
int last_active;
|
2008-09-20 19:42:25 +02:00
|
|
|
};
|
|
|
|
|
2013-11-29 06:29:39 +01:00
|
|
|
// holds counters and gauges for the uTP sockets
|
|
|
|
struct TORRENT_EXPORT utp_status
|
2010-11-29 02:33:05 +01:00
|
|
|
{
|
2013-11-29 06:29:39 +01:00
|
|
|
// gauges. These are snapshots of the number of
|
|
|
|
// uTP sockets in each respective state
|
2010-11-29 02:33:05 +01:00
|
|
|
int num_idle;
|
|
|
|
int num_syn_sent;
|
|
|
|
int num_connected;
|
|
|
|
int num_fin_sent;
|
|
|
|
int num_close_wait;
|
2013-09-14 12:06:48 +02:00
|
|
|
|
2013-11-29 06:29:39 +01:00
|
|
|
// counters. These are monotonically increasing
|
|
|
|
// and cumulative counters for their respective event.
|
2013-09-14 12:06:48 +02:00
|
|
|
boost::uint64_t packet_loss;
|
|
|
|
boost::uint64_t timeout;
|
|
|
|
boost::uint64_t packets_in;
|
|
|
|
boost::uint64_t packets_out;
|
|
|
|
boost::uint64_t fast_retransmit;
|
|
|
|
boost::uint64_t packet_resend;
|
|
|
|
boost::uint64_t samples_above_target;
|
|
|
|
boost::uint64_t samples_below_target;
|
|
|
|
boost::uint64_t payload_pkts_in;
|
|
|
|
boost::uint64_t payload_pkts_out;
|
|
|
|
boost::uint64_t invalid_pkts_in;
|
|
|
|
boost::uint64_t redundant_pkts_in;
|
2010-11-29 02:33:05 +01:00
|
|
|
};
|
|
|
|
|
2013-11-29 06:29:39 +01:00
|
|
|
// contains session wide state and counters
|
2006-09-05 01:22:21 +02:00
|
|
|
struct TORRENT_EXPORT session_status
|
|
|
|
{
|
2013-07-21 07:05:21 +02:00
|
|
|
// false as long as no incoming connections have been
|
|
|
|
// established on the listening socket. Every time you change the listen port, this will
|
|
|
|
// be reset to false.
|
2006-09-05 01:22:21 +02:00
|
|
|
bool has_incoming_connections;
|
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// the total download and upload rates accumulated
|
|
|
|
// from all torrents. This includes bittorrent protocol, DHT and an estimated TCP/IP
|
|
|
|
// protocol overhead.
|
2009-07-19 06:59:27 +02:00
|
|
|
int upload_rate;
|
|
|
|
int download_rate;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// the total number of bytes downloaded and
|
|
|
|
// uploaded to and from all torrents. This also includes all the protocol overhead.
|
2006-09-05 01:22:21 +02:00
|
|
|
size_type total_download;
|
|
|
|
size_type total_upload;
|
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// the rate of the payload
|
|
|
|
// down- and upload only.
|
2009-07-19 06:59:27 +02:00
|
|
|
int payload_upload_rate;
|
|
|
|
int payload_download_rate;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// the total transfers of payload
|
|
|
|
// only. The payload does not include the bittorrent protocol overhead, but only parts of the
|
|
|
|
// actual files to be downloaded.
|
2006-09-05 01:22:21 +02:00
|
|
|
size_type total_payload_download;
|
|
|
|
size_type total_payload_upload;
|
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// the estimated TCP/IP overhead in each direction.
|
2009-07-19 06:59:27 +02:00
|
|
|
int ip_overhead_upload_rate;
|
|
|
|
int ip_overhead_download_rate;
|
2008-09-20 19:42:25 +02:00
|
|
|
size_type total_ip_overhead_download;
|
|
|
|
size_type total_ip_overhead_upload;
|
|
|
|
|
2013-09-01 19:34:05 +02:00
|
|
|
// the upload and download rate used by DHT traffic. Also the total number
|
|
|
|
// of bytes sent and received to and from the DHT.
|
2009-07-19 06:59:27 +02:00
|
|
|
int dht_upload_rate;
|
|
|
|
int dht_download_rate;
|
2008-09-20 19:42:25 +02:00
|
|
|
size_type total_dht_download;
|
|
|
|
size_type total_dht_upload;
|
|
|
|
|
2013-09-01 19:34:05 +02:00
|
|
|
// the upload and download rate used by tracker traffic. Also the total number
|
|
|
|
// of bytes sent and received to and from trackers.
|
2009-07-19 06:59:27 +02:00
|
|
|
int tracker_upload_rate;
|
|
|
|
int tracker_download_rate;
|
2008-09-22 02:15:05 +02:00
|
|
|
size_type total_tracker_download;
|
|
|
|
size_type total_tracker_upload;
|
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// the number of bytes that has been received more than once.
|
|
|
|
// This can happen if a request from a peer times out and is requested from a different
|
|
|
|
// peer, and then received again from the first one. To make this lower, increase the
|
|
|
|
// ``request_timeout`` and the ``piece_timeout`` in the session settings.
|
2008-07-11 09:30:04 +02:00
|
|
|
size_type total_redundant_bytes;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// the number of bytes that was downloaded which later failed
|
|
|
|
// the hash-check.
|
2008-07-11 09:30:04 +02:00
|
|
|
size_type total_failed_bytes;
|
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// the total number of peer connections this session has. This includes
|
|
|
|
// incoming connections that still hasn't sent their handshake or outgoing connections
|
|
|
|
// that still hasn't completed the TCP connection. This number may be slightly higher
|
|
|
|
// than the sum of all peers of all torrents because the incoming connections may not
|
|
|
|
// be assigned a torrent yet.
|
2006-09-05 01:22:21 +02:00
|
|
|
int num_peers;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// the current number of unchoked peers.
|
2008-01-13 12:18:18 +01:00
|
|
|
int num_unchoked;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// the current allowed number of unchoked peers.
|
2008-01-13 12:18:18 +01:00
|
|
|
int allowed_upload_slots;
|
2006-09-05 01:22:21 +02:00
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// the number of peers that are
|
|
|
|
// waiting for more bandwidth quota from the torrent rate limiter.
|
2008-01-17 18:40:46 +01:00
|
|
|
int up_bandwidth_queue;
|
|
|
|
int down_bandwidth_queue;
|
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// count the number of
|
|
|
|
// bytes the connections are waiting for to be able to send and receive.
|
2008-12-13 06:12:12 +01:00
|
|
|
int up_bandwidth_bytes_queue;
|
|
|
|
int down_bandwidth_bytes_queue;
|
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// tells the number of
|
|
|
|
// seconds until the next optimistic unchoke change and the start of the next
|
|
|
|
// unchoke interval. These numbers may be reset prematurely if a peer that is
|
|
|
|
// unchoked disconnects or becomes notinterested.
|
2008-10-19 00:35:10 +02:00
|
|
|
int optimistic_unchoke_counter;
|
|
|
|
int unchoke_counter;
|
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// the number of peers currently
|
|
|
|
// waiting on a disk write or disk read to complete before it receives or sends
|
|
|
|
// any more data on the socket. It'a a metric of how disk bound you are.
|
2011-01-30 11:04:15 +01:00
|
|
|
int disk_write_queue;
|
|
|
|
int disk_read_queue;
|
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// only available when
|
|
|
|
// built with DHT support. They are all set to 0 if the DHT isn't running. When
|
|
|
|
// the DHT is running, ``dht_nodes`` is set to the number of nodes in the routing
|
|
|
|
// table. This number only includes *active* nodes, not cache nodes. The
|
|
|
|
// ``dht_node_cache`` is set to the number of nodes in the node cache. These nodes
|
|
|
|
// are used to replace the regular nodes in the routing table in case any of them
|
|
|
|
// becomes unresponsive.
|
2006-11-28 19:18:37 +01:00
|
|
|
int dht_nodes;
|
|
|
|
int dht_node_cache;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// the number of torrents tracked by the DHT at the moment.
|
2006-11-28 19:18:37 +01:00
|
|
|
int dht_torrents;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// an estimation of the total number of nodes in the DHT
|
|
|
|
// network.
|
2007-05-12 03:52:25 +02:00
|
|
|
size_type dht_global_nodes;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// a vector of the currently running DHT lookups.
|
2008-09-20 19:42:25 +02:00
|
|
|
std::vector<dht_lookup> active_requests;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// contains information about every bucket in the DHT routing
|
|
|
|
// table.
|
2010-12-12 04:17:08 +01:00
|
|
|
std::vector<dht_routing_bucket> dht_routing_table;
|
2013-07-21 07:05:21 +02:00
|
|
|
|
|
|
|
// the number of nodes allocated dynamically for a
|
|
|
|
// particular DHT lookup. This represents roughly the amount of memory used
|
|
|
|
// by the DHT.
|
2010-11-06 08:12:57 +01:00
|
|
|
int dht_total_allocations;
|
2010-10-01 06:07:38 +02:00
|
|
|
|
2013-07-21 07:05:21 +02:00
|
|
|
// statistics on the uTP sockets.
|
2010-11-29 02:33:05 +01:00
|
|
|
utp_status utp_stats;
|
|
|
|
|
2013-09-01 19:34:05 +02:00
|
|
|
// the number of known peers across all torrents. These are not necessarily
|
|
|
|
// connected peers, just peers we know of.
|
2010-10-01 06:07:38 +02:00
|
|
|
int peerlist_size;
|
2006-09-05 01:22:21 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif // TORRENT_SESSION_STATUS_HPP_INCLUDED
|
|
|
|
|