move documentation from manual.rst to headers
This commit is contained in:
parent
f5f868ba68
commit
39935df784
1236
docs/manual.html
1236
docs/manual.html
File diff suppressed because it is too large
Load Diff
252
docs/manual.rst
252
docs/manual.rst
|
@ -169,80 +169,6 @@ with a DHT ping packet, and connect to those that responds first. On windows one
|
||||||
can only connect to a few peers at a time because of a built in limitation (in XP
|
can only connect to a few peers at a time because of a built in limitation (in XP
|
||||||
Service pack 2).
|
Service pack 2).
|
||||||
|
|
||||||
set_alert_mask()
|
|
||||||
----------------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
void set_alert_mask(int m);
|
|
||||||
|
|
||||||
Changes the mask of which alerts to receive. By default only errors are reported.
|
|
||||||
``m`` is a bitmask where each bit represents a category of alerts.
|
|
||||||
|
|
||||||
See alerts_ for mor information on the alert categories.
|
|
||||||
|
|
||||||
pop_alerts() pop_alert() wait_for_alert()
|
|
||||||
-----------------------------------------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
std::auto_ptr<alert> pop_alert();
|
|
||||||
void pop_alerts(std::deque<alert*>* alerts);
|
|
||||||
alert const* wait_for_alert(time_duration max_wait);
|
|
||||||
|
|
||||||
``pop_alert()`` is used to ask the session if any errors or events has occurred. With
|
|
||||||
`set_alert_mask()`_ you can filter which alerts to receive through ``pop_alert()``.
|
|
||||||
For information about the alert categories, see alerts_.
|
|
||||||
|
|
||||||
``pop_alerts()`` pops all pending alerts in a single call. In high performance environments
|
|
||||||
with a very high alert churn rate, this can save significant amount of time compared to
|
|
||||||
popping alerts one at a time. Each call requires one round-trip to the network thread. If
|
|
||||||
alerts are produced in a higher rate than they can be popped (when popped one at a time)
|
|
||||||
it's easy to get stuck in an infinite loop, trying to drain the alert queue. Popping the entire
|
|
||||||
queue at once avoids this problem.
|
|
||||||
|
|
||||||
However, the ``pop_alerts`` function comes with significantly more responsibility. You pass
|
|
||||||
in an *empty* ``std::dequeue<alert*>`` to it. If it's not empty, all elements in it will
|
|
||||||
be deleted and then cleared. All currently pending alerts are returned by being swapped
|
|
||||||
into the passed in container. The responsibility of deleting the alerts is transferred
|
|
||||||
to the caller. This means you need to call delete for each item in the returned dequeue.
|
|
||||||
It's probably a good idea to delete the alerts as you handle them, to save one extra
|
|
||||||
pass over the dequeue.
|
|
||||||
|
|
||||||
Alternatively, you can pass in the same container the next time you call ``pop_alerts``.
|
|
||||||
|
|
||||||
``wait_for_alert`` blocks until an alert is available, or for no more than ``max_wait``
|
|
||||||
time. If ``wait_for_alert`` returns because of the time-out, and no alerts are available,
|
|
||||||
it returns 0. If at least one alert was generated, a pointer to that alert is returned.
|
|
||||||
The alert is not popped, any subsequent calls to ``wait_for_alert`` will return the
|
|
||||||
same pointer until the alert is popped by calling ``pop_alert``. This is useful for
|
|
||||||
leaving any alert dispatching mechanism independent of this blocking call, the dispatcher
|
|
||||||
can be called and it can pop the alert independently.
|
|
||||||
|
|
||||||
In the python binding, ``wait_for_alert`` takes the number of milliseconds to wait as an integer.
|
|
||||||
|
|
||||||
To control the max number of alerts that's queued by the session, see
|
|
||||||
``session_settings::alert_queue_size``.
|
|
||||||
|
|
||||||
``save_resume_data_alert`` and ``save_resume_data_failed_alert`` are always posted, regardelss
|
|
||||||
of the alert mask.
|
|
||||||
|
|
||||||
set_alert_dispatch()
|
|
||||||
--------------------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
void set_alert_dispatch(boost::function<void(std::auto_ptr<alert>)> const& fun);
|
|
||||||
|
|
||||||
This sets a function to be called (from within libtorrent's netowrk thread) every time an alert
|
|
||||||
is posted. Since the function (``fun``) is run in libtorrent's internal thread, it may not call
|
|
||||||
any of libtorrent's external API functions. Doing so results in a dead lock.
|
|
||||||
|
|
||||||
The main intention with this function is to support integration with platform-dependent message
|
|
||||||
queues or signalling systems. For instance, on windows, one could post a message to an HNWD or
|
|
||||||
on linux, write to a pipe or an eventfd.
|
|
||||||
|
|
||||||
|
|
||||||
add_feed()
|
add_feed()
|
||||||
----------
|
----------
|
||||||
|
|
||||||
|
@ -420,184 +346,6 @@ are ``hostname`` and ``port``.
|
||||||
|
|
||||||
.. _i2p: http://www.i2p2.de
|
.. _i2p: http://www.i2p2.de
|
||||||
|
|
||||||
|
|
||||||
start_dht() stop_dht() set_dht_settings() dht_state() is_dht_running()
|
|
||||||
----------------------------------------------------------------------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
void start_dht(entry const& startup_state);
|
|
||||||
void stop_dht();
|
|
||||||
void set_dht_settings(dht_settings const& settings);
|
|
||||||
entry dht_state() const;
|
|
||||||
bool is_dht_running() const;
|
|
||||||
|
|
||||||
These functions are not available in case ``TORRENT_DISABLE_DHT`` is
|
|
||||||
defined. ``start_dht`` starts the dht node and makes the trackerless service
|
|
||||||
available to torrents. The startup state is optional and can contain nodes
|
|
||||||
and the node id from the previous session. The dht node state is a bencoded
|
|
||||||
dictionary with the following entries:
|
|
||||||
|
|
||||||
``nodes``
|
|
||||||
A list of strings, where each string is a node endpoint encoded in binary. If
|
|
||||||
the string is 6 bytes long, it is an IPv4 address of 4 bytes, encoded in
|
|
||||||
network byte order (big endian), followed by a 2 byte port number (also
|
|
||||||
network byte order). If the string is 18 bytes long, it is 16 bytes of IPv6
|
|
||||||
address followed by a 2 bytes port number (also network byte order).
|
|
||||||
|
|
||||||
``node-id``
|
|
||||||
The node id written as a readable string as a hexadecimal number.
|
|
||||||
|
|
||||||
``dht_state`` will return the current state of the dht node, this can be used
|
|
||||||
to start up the node again, passing this entry to ``start_dht``. It is a good
|
|
||||||
idea to save this to disk when the session is closed, and read it up again
|
|
||||||
when starting.
|
|
||||||
|
|
||||||
If the port the DHT is supposed to listen on is already in use, and exception
|
|
||||||
is thrown, ``asio::error``.
|
|
||||||
|
|
||||||
``stop_dht`` stops the dht node.
|
|
||||||
|
|
||||||
``add_dht_node`` adds a node to the routing table. This can be used if your
|
|
||||||
client has its own source of bootstrapping nodes.
|
|
||||||
|
|
||||||
``set_dht_settings`` sets some parameters availavle to the dht node. The
|
|
||||||
struct has the following members::
|
|
||||||
|
|
||||||
struct dht_settings
|
|
||||||
{
|
|
||||||
int max_peers_reply;
|
|
||||||
int search_branching;
|
|
||||||
int max_fail_count;
|
|
||||||
int max_torrents;
|
|
||||||
bool restrict_routing_ips;
|
|
||||||
bool restrict_search_ips;
|
|
||||||
bool extended_routing_table;
|
|
||||||
bool aggressive_lookups;
|
|
||||||
};
|
|
||||||
|
|
||||||
``max_peers_reply`` is the maximum number of peers the node will send in
|
|
||||||
response to a ``get_peers`` message from another node.
|
|
||||||
|
|
||||||
``search_branching`` is the number of concurrent search request the node will
|
|
||||||
send when announcing and refreshing the routing table. This parameter is
|
|
||||||
called alpha in the kademlia paper.
|
|
||||||
|
|
||||||
``max_fail_count`` is the maximum number of failed tries to contact a node
|
|
||||||
before it is removed from the routing table. If there are known working nodes
|
|
||||||
that are ready to replace a failing node, it will be replaced immediately,
|
|
||||||
this limit is only used to clear out nodes that don't have any node that can
|
|
||||||
replace them.
|
|
||||||
|
|
||||||
``max_torrents`` is the total number of torrents to track from the DHT. This
|
|
||||||
is simply an upper limit to make sure malicious DHT nodes cannot make us allocate
|
|
||||||
an unbounded amount of memory.
|
|
||||||
|
|
||||||
``max_feed_items`` is the total number of feed items to store from the DHT. This
|
|
||||||
is simply an upper limit to make sure malicious DHT nodes cannot make us allocate
|
|
||||||
an unbounded amount of memory.
|
|
||||||
|
|
||||||
``restrict_routing_ips`` determines if the routing table entries should restrict
|
|
||||||
entries to one per IP. This defaults to true, which helps mitigate some attacks
|
|
||||||
on the DHT. It prevents adding multiple nodes with IPs with a very close CIDR
|
|
||||||
distance.
|
|
||||||
|
|
||||||
``restrict_search_ips`` determines if DHT searches should prevent adding nodes
|
|
||||||
with IPs with very close CIDR distance. This also defaults to true and helps
|
|
||||||
mitigate certain attacks on the DHT.
|
|
||||||
|
|
||||||
``extended_routing_table`` makes the first buckets in the DHT routing
|
|
||||||
table fit 128, 64, 32 and 16 nodes respectively, as opposed to the
|
|
||||||
standard size of 8. All other buckets have size 8 still.
|
|
||||||
|
|
||||||
The ``dht_settings`` struct used to contain a ``service_port`` member to control
|
|
||||||
which port the DHT would listen on and send messages from. This field is deprecated
|
|
||||||
and ignored. libtorrent always tries to open the UDP socket on the same port
|
|
||||||
as the TCP socket.
|
|
||||||
|
|
||||||
``aggressive_lookups`` slightly changes the lookup behavior in terms of how
|
|
||||||
many outstanding requests we keep. Instead of having branch factor be a hard
|
|
||||||
limit, we always keep *branch factor* outstanding requests to the closest nodes.
|
|
||||||
i.e. every time we get results back with closer nodes, we query them right away.
|
|
||||||
It lowers the lookup times at the cost of more outstanding queries.
|
|
||||||
|
|
||||||
``is_dht_running()`` returns true if the DHT support has been started and false
|
|
||||||
otherwise.
|
|
||||||
|
|
||||||
|
|
||||||
add_dht_node() add_dht_router()
|
|
||||||
-------------------------------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
void add_dht_node(std::pair<std::string, int> const& node);
|
|
||||||
void add_dht_router(std::pair<std::string, int> const& node);
|
|
||||||
|
|
||||||
``add_dht_node`` takes a host name and port pair. That endpoint will be
|
|
||||||
pinged, and if a valid DHT reply is received, the node will be added to
|
|
||||||
the routing table.
|
|
||||||
|
|
||||||
``add_dht_router`` adds the given endpoint to a list of DHT router nodes.
|
|
||||||
If a search is ever made while the routing table is empty, those nodes will
|
|
||||||
be used as backups. Nodes in the router node list will also never be added
|
|
||||||
to the regular routing table, which effectively means they are only used
|
|
||||||
for bootstrapping, to keep the load off them.
|
|
||||||
|
|
||||||
An example routing node that you could typically add is
|
|
||||||
``router.bittorrent.com``.
|
|
||||||
|
|
||||||
|
|
||||||
start_lsd() stop_lsd()
|
|
||||||
----------------------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
void start_lsd();
|
|
||||||
void stop_lsd();
|
|
||||||
|
|
||||||
Starts and stops Local Service Discovery. This service will broadcast
|
|
||||||
the infohashes of all the non-private torrents on the local network to
|
|
||||||
look for peers on the same swarm within multicast reach.
|
|
||||||
|
|
||||||
It is turned off by default.
|
|
||||||
|
|
||||||
start_upnp() stop_upnp()
|
|
||||||
------------------------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
upnp* start_upnp();
|
|
||||||
void stop_upnp();
|
|
||||||
|
|
||||||
Starts and stops the UPnP service. When started, the listen port and the DHT
|
|
||||||
port are attempted to be forwarded on local UPnP router devices.
|
|
||||||
|
|
||||||
The upnp object returned by ``start_upnp()`` can be used to add and remove
|
|
||||||
arbitrary port mappings. Mapping status is returned through the
|
|
||||||
portmap_alert_ and the portmap_error_alert_. The object will be valid until
|
|
||||||
``stop_upnp()`` is called. See `UPnP and NAT-PMP`_.
|
|
||||||
|
|
||||||
It is off by default.
|
|
||||||
|
|
||||||
start_natpmp() stop_natpmp()
|
|
||||||
----------------------------
|
|
||||||
|
|
||||||
::
|
|
||||||
|
|
||||||
natpmp* start_natpmp();
|
|
||||||
void stop_natpmp();
|
|
||||||
|
|
||||||
Starts and stops the NAT-PMP service. When started, the listen port and the DHT
|
|
||||||
port are attempted to be forwarded on the router through NAT-PMP.
|
|
||||||
|
|
||||||
The natpmp object returned by ``start_natpmp()`` can be used to add and remove
|
|
||||||
arbitrary port mappings. Mapping status is returned through the
|
|
||||||
portmap_alert_ and the portmap_error_alert_. The object will be valid until
|
|
||||||
``stop_natpmp()`` is called. See `UPnP and NAT-PMP`_.
|
|
||||||
|
|
||||||
It is off by default.
|
|
||||||
|
|
||||||
|
|
||||||
entry
|
entry
|
||||||
=====
|
=====
|
||||||
|
|
||||||
|
|
|
@ -363,12 +363,62 @@ namespace libtorrent
|
||||||
void remove_feed(feed_handle h);
|
void remove_feed(feed_handle h);
|
||||||
void get_feeds(std::vector<feed_handle>& f) const;
|
void get_feeds(std::vector<feed_handle>& f) const;
|
||||||
|
|
||||||
|
// starts/stops UPnP, NATPMP or LSD port mappers
|
||||||
|
// they are stopped by default
|
||||||
|
// These functions are not available in case ``TORRENT_DISABLE_DHT`` is
|
||||||
|
// defined. ``start_dht`` starts the dht node and makes the trackerless service
|
||||||
|
// available to torrents. The startup state is optional and can contain nodes
|
||||||
|
// and the node id from the previous session. The dht node state is a bencoded
|
||||||
|
// dictionary with the following entries:
|
||||||
|
//
|
||||||
|
// nodes
|
||||||
|
// A list of strings, where each string is a node endpoint encoded in binary. If
|
||||||
|
// the string is 6 bytes long, it is an IPv4 address of 4 bytes, encoded in
|
||||||
|
// network byte order (big endian), followed by a 2 byte port number (also
|
||||||
|
// network byte order). If the string is 18 bytes long, it is 16 bytes of IPv6
|
||||||
|
// address followed by a 2 bytes port number (also network byte order).
|
||||||
|
//
|
||||||
|
// node-id
|
||||||
|
// The node id written as a readable string as a hexadecimal number.
|
||||||
|
//
|
||||||
|
// ``dht_state`` will return the current state of the dht node, this can be used
|
||||||
|
// to start up the node again, passing this entry to ``start_dht``. It is a good
|
||||||
|
// idea to save this to disk when the session is closed, and read it up again
|
||||||
|
// when starting.
|
||||||
|
//
|
||||||
|
// If the port the DHT is supposed to listen on is already in use, and exception
|
||||||
|
// is thrown, ``asio::error``.
|
||||||
|
//
|
||||||
|
// ``stop_dht`` stops the dht node.
|
||||||
|
//
|
||||||
|
// ``add_dht_node`` adds a node to the routing table. This can be used if your
|
||||||
|
// client has its own source of bootstrapping nodes.
|
||||||
|
//
|
||||||
|
// ``set_dht_settings`` sets some parameters availavle to the dht node. See
|
||||||
|
// dht_settings_ for more information.
|
||||||
|
//
|
||||||
|
// ``is_dht_running()`` returns true if the DHT support has been started and false
|
||||||
|
// otherwise.
|
||||||
void start_dht();
|
void start_dht();
|
||||||
void stop_dht();
|
void stop_dht();
|
||||||
void set_dht_settings(dht_settings const& settings);
|
void set_dht_settings(dht_settings const& settings);
|
||||||
|
bool is_dht_running() const;
|
||||||
|
|
||||||
|
// ``add_dht_node`` takes a host name and port pair. That endpoint will be
|
||||||
|
// pinged, and if a valid DHT reply is received, the node will be added to
|
||||||
|
// the routing table.
|
||||||
|
//
|
||||||
|
// ``add_dht_router`` adds the given endpoint to a list of DHT router nodes.
|
||||||
|
// If a search is ever made while the routing table is empty, those nodes will
|
||||||
|
// be used as backups. Nodes in the router node list will also never be added
|
||||||
|
// to the regular routing table, which effectively means they are only used
|
||||||
|
// for bootstrapping, to keep the load off them.
|
||||||
|
//
|
||||||
|
// An example routing node that you could typically add is
|
||||||
|
// ``router.bittorrent.com``.
|
||||||
void add_dht_node(std::pair<std::string, int> const& node);
|
void add_dht_node(std::pair<std::string, int> const& node);
|
||||||
void add_dht_router(std::pair<std::string, int> const& node);
|
void add_dht_router(std::pair<std::string, int> const& node);
|
||||||
bool is_dht_running() const;
|
|
||||||
#ifndef TORRENT_NO_DEPRECATE
|
#ifndef TORRENT_NO_DEPRECATE
|
||||||
// deprecated in 0.15
|
// deprecated in 0.15
|
||||||
// use save_state and load_state instead
|
// use save_state and load_state instead
|
||||||
|
@ -574,19 +624,45 @@ namespace libtorrent
|
||||||
int max_uploads() const TORRENT_DEPRECATED;
|
int max_uploads() const TORRENT_DEPRECATED;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// pop one alert from the alert queue, or do nothing
|
// ``pop_alert()`` is used to ask the session if any errors or events has occurred. With
|
||||||
// and return a NULL pointer if there are no alerts
|
// `set_alert_mask()`_ you can filter which alerts to receive through ``pop_alert()``.
|
||||||
// in the queue
|
// For information about the alert categories, see alerts_.
|
||||||
|
//
|
||||||
|
// ``pop_alerts()`` pops all pending alerts in a single call. In high performance environments
|
||||||
|
// with a very high alert churn rate, this can save significant amount of time compared to
|
||||||
|
// popping alerts one at a time. Each call requires one round-trip to the network thread. If
|
||||||
|
// alerts are produced in a higher rate than they can be popped (when popped one at a time)
|
||||||
|
// it's easy to get stuck in an infinite loop, trying to drain the alert queue. Popping the entire
|
||||||
|
// queue at once avoids this problem.
|
||||||
|
//
|
||||||
|
// However, the ``pop_alerts`` function comes with significantly more responsibility. You pass
|
||||||
|
// in an *empty* ``std::dequeue<alert*>`` to it. If it's not empty, all elements in it will
|
||||||
|
// be deleted and then cleared. All currently pending alerts are returned by being swapped
|
||||||
|
// into the passed in container. The responsibility of deleting the alerts is transferred
|
||||||
|
// to the caller. This means you need to call delete for each item in the returned dequeue.
|
||||||
|
// It's probably a good idea to delete the alerts as you handle them, to save one extra
|
||||||
|
// pass over the dequeue.
|
||||||
|
//
|
||||||
|
// Alternatively, you can pass in the same container the next time you call ``pop_alerts``.
|
||||||
|
//
|
||||||
|
// ``wait_for_alert`` blocks until an alert is available, or for no more than ``max_wait``
|
||||||
|
// time. If ``wait_for_alert`` returns because of the time-out, and no alerts are available,
|
||||||
|
// it returns 0. If at least one alert was generated, a pointer to that alert is returned.
|
||||||
|
// The alert is not popped, any subsequent calls to ``wait_for_alert`` will return the
|
||||||
|
// same pointer until the alert is popped by calling ``pop_alert``. This is useful for
|
||||||
|
// leaving any alert dispatching mechanism independent of this blocking call, the dispatcher
|
||||||
|
// can be called and it can pop the alert independently.
|
||||||
|
//
|
||||||
|
// In the python binding, ``wait_for_alert`` takes the number of milliseconds to wait as an integer.
|
||||||
|
//
|
||||||
|
// To control the max number of alerts that's queued by the session, see
|
||||||
|
// ``session_settings::alert_queue_size``.
|
||||||
|
//
|
||||||
|
// ``save_resume_data_alert`` and ``save_resume_data_failed_alert`` are always posted, regardelss
|
||||||
|
// of the alert mask.
|
||||||
std::auto_ptr<alert> pop_alert();
|
std::auto_ptr<alert> pop_alert();
|
||||||
|
|
||||||
// pop all alerts in the alert queue and returns them
|
|
||||||
// in the supplied dequeue 'alerts'. The passed in
|
|
||||||
// queue must be empty when passed in.
|
|
||||||
// the responsibility of individual alerts returned
|
|
||||||
// in the dequeue is passed on to the caller of this function.
|
|
||||||
// when you're done with reacting to the alerts, you need to
|
|
||||||
// delete them all.
|
|
||||||
void pop_alerts(std::deque<alert*>* alerts);
|
void pop_alerts(std::deque<alert*>* alerts);
|
||||||
|
alert const* wait_for_alert(time_duration max_wait);
|
||||||
|
|
||||||
#ifndef TORRENT_NO_DEPRECATE
|
#ifndef TORRENT_NO_DEPRECATE
|
||||||
TORRENT_DEPRECATED_PREFIX
|
TORRENT_DEPRECATED_PREFIX
|
||||||
|
@ -595,23 +671,56 @@ namespace libtorrent
|
||||||
TORRENT_DEPRECATED_PREFIX
|
TORRENT_DEPRECATED_PREFIX
|
||||||
size_t set_alert_queue_size_limit(size_t queue_size_limit_) TORRENT_DEPRECATED;
|
size_t set_alert_queue_size_limit(size_t queue_size_limit_) TORRENT_DEPRECATED;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
// Changes the mask of which alerts to receive. By default only errors are reported.
|
||||||
|
// ``m`` is a bitmask where each bit represents a category of alerts.
|
||||||
|
//
|
||||||
|
// See alerts_ for mor information on the alert categories.
|
||||||
void set_alert_mask(boost::uint32_t m);
|
void set_alert_mask(boost::uint32_t m);
|
||||||
|
|
||||||
alert const* wait_for_alert(time_duration max_wait);
|
// This sets a function to be called (from within libtorrent's netowrk thread) every time an alert
|
||||||
|
// is posted. Since the function (``fun``) is run in libtorrent's internal thread, it may not call
|
||||||
|
// any of libtorrent's external API functions. Doing so results in a dead lock.
|
||||||
|
//
|
||||||
|
// The main intention with this function is to support integration with platform-dependent message
|
||||||
|
// queues or signalling systems. For instance, on windows, one could post a message to an HNWD or
|
||||||
|
// on linux, write to a pipe or an eventfd.
|
||||||
void set_alert_dispatch(boost::function<void(std::auto_ptr<alert>)> const& fun);
|
void set_alert_dispatch(boost::function<void(std::auto_ptr<alert>)> const& fun);
|
||||||
|
|
||||||
connection_queue& get_connection_queue();
|
connection_queue& get_connection_queue();
|
||||||
|
|
||||||
// starts/stops UPnP, NATPMP or LSD port mappers
|
// Starts and stops Local Service Discovery. This service will broadcast
|
||||||
// they are stopped by default
|
// the infohashes of all the non-private torrents on the local network to
|
||||||
|
// look for peers on the same swarm within multicast reach.
|
||||||
|
//
|
||||||
|
// It is turned off by default.
|
||||||
void start_lsd();
|
void start_lsd();
|
||||||
void start_natpmp();
|
|
||||||
void start_upnp();
|
|
||||||
|
|
||||||
void stop_lsd();
|
void stop_lsd();
|
||||||
void stop_natpmp();
|
|
||||||
|
// Starts and stops the UPnP service. When started, the listen port and the DHT
|
||||||
|
// port are attempted to be forwarded on local UPnP router devices.
|
||||||
|
//
|
||||||
|
// The upnp object returned by ``start_upnp()`` can be used to add and remove
|
||||||
|
// arbitrary port mappings. Mapping status is returned through the
|
||||||
|
// portmap_alert_ and the portmap_error_alert_. The object will be valid until
|
||||||
|
// ``stop_upnp()`` is called. See `UPnP and NAT-PMP`_.
|
||||||
|
//
|
||||||
|
// It is off by default.
|
||||||
|
void start_upnp();
|
||||||
void stop_upnp();
|
void stop_upnp();
|
||||||
|
|
||||||
|
// Starts and stops the NAT-PMP service. When started, the listen port and the DHT
|
||||||
|
// port are attempted to be forwarded on the router through NAT-PMP.
|
||||||
|
//
|
||||||
|
// The natpmp object returned by ``start_natpmp()`` can be used to add and remove
|
||||||
|
// arbitrary port mappings. Mapping status is returned through the
|
||||||
|
// portmap_alert_ and the portmap_error_alert_. The object will be valid until
|
||||||
|
// ``stop_natpmp()`` is called. See `UPnP and NAT-PMP`_.
|
||||||
|
//
|
||||||
|
// It is off by default.
|
||||||
|
void start_natpmp();
|
||||||
|
void stop_natpmp();
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
||||||
void init(std::pair<int, int> listen_range, char const* listen_interface
|
void init(std::pair<int, int> listen_range, char const* listen_interface
|
||||||
|
|
|
@ -973,6 +973,12 @@ namespace libtorrent
|
||||||
bool use_disk_cache_pool;
|
bool use_disk_cache_pool;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// structure used to hold configuration options for the DHT
|
||||||
|
//
|
||||||
|
// The ``dht_settings`` struct used to contain a ``service_port`` member to control
|
||||||
|
// which port the DHT would listen on and send messages from. This field is deprecated
|
||||||
|
// and ignored. libtorrent always tries to open the UDP socket on the same port
|
||||||
|
// as the TCP socket.
|
||||||
struct dht_settings
|
struct dht_settings
|
||||||
{
|
{
|
||||||
dht_settings()
|
dht_settings()
|
||||||
|
@ -992,11 +998,12 @@ namespace libtorrent
|
||||||
{}
|
{}
|
||||||
|
|
||||||
// the maximum number of peers to send in a
|
// the maximum number of peers to send in a
|
||||||
// reply to get_peers
|
// reply to ``get_peers``
|
||||||
int max_peers_reply;
|
int max_peers_reply;
|
||||||
|
|
||||||
// the number of simultanous "connections" when
|
// the number of concurrent search request the node will
|
||||||
// searching the DHT.
|
// send when announcing and refreshing the routing table. This parameter is
|
||||||
|
// called alpha in the kademlia paper
|
||||||
int search_branching;
|
int search_branching;
|
||||||
|
|
||||||
#ifndef TORRENT_NO_DEPRECATE
|
#ifndef TORRENT_NO_DEPRECATE
|
||||||
|
@ -1005,11 +1012,16 @@ namespace libtorrent
|
||||||
int service_port;
|
int service_port;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
// the maximum number of times a node can fail
|
// the maximum number of failed tries to contact a node
|
||||||
// in a row before it is removed from the table.
|
// before it is removed from the routing table. If there are known working nodes
|
||||||
|
// that are ready to replace a failing node, it will be replaced immediately,
|
||||||
|
// this limit is only used to clear out nodes that don't have any node that can
|
||||||
|
// replace them.
|
||||||
int max_fail_count;
|
int max_fail_count;
|
||||||
|
|
||||||
// this is the max number of torrents the DHT will track
|
// the total number of torrents to track from the DHT. This
|
||||||
|
// is simply an upper limit to make sure malicious DHT nodes cannot make us allocate
|
||||||
|
// an unbounded amount of memory.
|
||||||
int max_torrents;
|
int max_torrents;
|
||||||
|
|
||||||
// max number of items the DHT will store
|
// max number of items the DHT will store
|
||||||
|
@ -1019,6 +1031,11 @@ namespace libtorrent
|
||||||
// torrent search query to the DHT
|
// torrent search query to the DHT
|
||||||
int max_torrent_search_reply;
|
int max_torrent_search_reply;
|
||||||
|
|
||||||
|
// determines if the routing table entries should restrict
|
||||||
|
// entries to one per IP. This defaults to true, which helps mitigate some attacks
|
||||||
|
// on the DHT. It prevents adding multiple nodes with IPs with a very close CIDR
|
||||||
|
// distance.
|
||||||
|
//
|
||||||
// when set, nodes whose IP address that's in
|
// when set, nodes whose IP address that's in
|
||||||
// the same /24 (or /64 for IPv6) range in the
|
// the same /24 (or /64 for IPv6) range in the
|
||||||
// same routing table bucket. This is an attempt
|
// same routing table bucket. This is an attempt
|
||||||
|
@ -1027,18 +1044,21 @@ namespace libtorrent
|
||||||
// entry in the whole routing table
|
// entry in the whole routing table
|
||||||
bool restrict_routing_ips;
|
bool restrict_routing_ips;
|
||||||
|
|
||||||
// applies the same IP restrictions on nodes
|
// determines if DHT searches should prevent adding nodes
|
||||||
// received during a DHT search (traversal algorithm)
|
// with IPs with very close CIDR distance. This also defaults to true and helps
|
||||||
|
// mitigate certain attacks on the DHT.
|
||||||
bool restrict_search_ips;
|
bool restrict_search_ips;
|
||||||
|
|
||||||
// if this is set, the first few buckets in the routing
|
// makes the first buckets in the DHT routing
|
||||||
// table are enlarged, to make room for more nodes in order
|
// table fit 128, 64, 32 and 16 nodes respectively, as opposed to the
|
||||||
// to lower the look-up times
|
// standard size of 8. All other buckets have size 8 still.
|
||||||
bool extended_routing_table;
|
bool extended_routing_table;
|
||||||
|
|
||||||
// makes lookups waste less time finding results,
|
// slightly changes the lookup behavior in terms of how
|
||||||
// at the cost of being more likely to keep more
|
// many outstanding requests we keep. Instead of having branch factor be a hard
|
||||||
// outstanding requests
|
// limit, we always keep *branch factor* outstanding requests to the closest nodes.
|
||||||
|
// i.e. every time we get results back with closer nodes, we query them right away.
|
||||||
|
// It lowers the lookup times at the cost of more outstanding queries.
|
||||||
bool aggressive_lookups;
|
bool aggressive_lookups;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue