2006-04-25 23:04:48 +02:00
|
|
|
/*
|
|
|
|
|
|
|
|
Copyright (c) 2003, Arvid Norberg
|
|
|
|
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_SETTINGS_HPP_INCLUDED
|
|
|
|
#define TORRENT_SESSION_SETTINGS_HPP_INCLUDED
|
|
|
|
|
2006-05-21 01:24:19 +02:00
|
|
|
#include "libtorrent/version.hpp"
|
2007-04-25 20:26:35 +02:00
|
|
|
#include "libtorrent/config.hpp"
|
2006-05-21 01:24:19 +02:00
|
|
|
|
2006-04-25 23:04:48 +02:00
|
|
|
namespace libtorrent
|
|
|
|
{
|
|
|
|
|
2007-04-25 20:26:35 +02:00
|
|
|
struct TORRENT_EXPORT proxy_settings
|
|
|
|
{
|
|
|
|
proxy_settings() : port(0), type(none) {}
|
|
|
|
|
|
|
|
std::string hostname;
|
|
|
|
int port;
|
|
|
|
|
|
|
|
std::string username;
|
|
|
|
std::string password;
|
|
|
|
|
|
|
|
enum proxy_type
|
|
|
|
{
|
|
|
|
// a plain tcp socket is used, and
|
|
|
|
// the other settings are ignored.
|
|
|
|
none,
|
2007-05-31 01:35:14 +02:00
|
|
|
// socks4 server, requires username.
|
|
|
|
socks4,
|
2007-04-25 20:26:35 +02:00
|
|
|
// the hostname and port settings are
|
|
|
|
// used to connect to the proxy. No
|
|
|
|
// username or password is sent.
|
|
|
|
socks5,
|
|
|
|
// the hostname and port are used to
|
|
|
|
// connect to the proxy. the username
|
|
|
|
// and password are used to authenticate
|
|
|
|
// with the proxy server.
|
|
|
|
socks5_pw,
|
|
|
|
// the http proxy is only available for
|
|
|
|
// tracker and web seed traffic
|
|
|
|
// assumes anonymous access to proxy
|
|
|
|
http,
|
|
|
|
// http proxy with basic authentication
|
|
|
|
// uses username and password
|
|
|
|
http_pw
|
|
|
|
};
|
|
|
|
|
|
|
|
proxy_type type;
|
|
|
|
|
|
|
|
};
|
|
|
|
|
2006-04-25 23:04:48 +02:00
|
|
|
struct TORRENT_EXPORT session_settings
|
|
|
|
{
|
2006-09-28 02:49:40 +02:00
|
|
|
session_settings(std::string const& user_agent_ = "libtorrent/"
|
2006-05-21 01:24:19 +02:00
|
|
|
LIBTORRENT_VERSION)
|
2007-04-25 20:26:35 +02:00
|
|
|
: user_agent(user_agent_)
|
2006-05-21 01:24:19 +02:00
|
|
|
, tracker_completion_timeout(60)
|
2007-11-30 18:37:50 +01:00
|
|
|
, tracker_receive_timeout(40)
|
2007-10-07 20:06:56 +02:00
|
|
|
, stop_tracker_timeout(5)
|
2006-05-21 01:24:19 +02:00
|
|
|
, tracker_maximum_response_length(1024*1024)
|
2007-10-22 22:58:42 +02:00
|
|
|
, piece_timeout(10)
|
2006-04-25 23:04:48 +02:00
|
|
|
, request_queue_time(3.f)
|
2006-05-15 00:30:05 +02:00
|
|
|
, max_allowed_in_request_queue(250)
|
|
|
|
, max_out_request_queue(200)
|
|
|
|
, whole_pieces_threshold(20)
|
2006-06-29 01:27:44 +02:00
|
|
|
, peer_timeout(120)
|
|
|
|
, urlseed_timeout(20)
|
2006-08-01 17:27:08 +02:00
|
|
|
, urlseed_pipeline_size(5)
|
2007-11-27 04:37:47 +01:00
|
|
|
, urlseed_wait_retry(30)
|
2006-11-14 16:53:38 +01:00
|
|
|
, file_pool_size(40)
|
|
|
|
, allow_multiple_connections_per_ip(false)
|
2007-04-14 23:47:07 +02:00
|
|
|
, max_failcount(3)
|
|
|
|
, min_reconnect_time(60)
|
2007-10-15 07:03:29 +02:00
|
|
|
, peer_connect_timeout(7)
|
2007-05-25 19:06:30 +02:00
|
|
|
, ignore_limits_on_local_network(true)
|
2007-05-25 23:00:35 +02:00
|
|
|
, connection_speed(20)
|
2007-05-25 23:19:14 +02:00
|
|
|
, send_redundant_have(false)
|
2007-05-27 00:27:40 +02:00
|
|
|
, lazy_bitfields(true)
|
2007-05-31 21:57:15 +02:00
|
|
|
, inactivity_timeout(600)
|
2007-08-16 14:41:46 +02:00
|
|
|
, unchoke_interval(15)
|
|
|
|
, optimistic_unchoke_multiplier(4)
|
2007-07-02 20:44:33 +02:00
|
|
|
, num_want(200)
|
2007-07-07 03:26:30 +02:00
|
|
|
, initial_picker_threshold(4)
|
2007-08-14 19:47:48 +02:00
|
|
|
, allowed_fast_set_size(10)
|
2007-08-03 10:19:10 +02:00
|
|
|
, max_outstanding_disk_bytes_per_connection(64 * 1024)
|
2007-10-23 02:19:28 +02:00
|
|
|
, handshake_timeout(10)
|
2007-02-18 19:28:07 +01:00
|
|
|
#ifndef TORRENT_DISABLE_DHT
|
2007-02-12 10:20:49 +01:00
|
|
|
, use_dht_as_fallback(true)
|
2007-02-18 19:28:07 +01:00
|
|
|
#endif
|
2007-11-19 05:58:52 +01:00
|
|
|
, free_torrent_hashes(true)
|
2008-01-07 06:48:28 +01:00
|
|
|
, upnp_ignore_nonrouters(true)
|
2008-01-08 02:16:30 +01:00
|
|
|
, send_buffer_watermark(80 * 1024)
|
2008-01-13 12:18:18 +01:00
|
|
|
, auto_upload_slots(true)
|
2006-05-15 00:30:05 +02:00
|
|
|
{}
|
2006-04-25 23:04:48 +02:00
|
|
|
|
2006-05-21 01:24:19 +02:00
|
|
|
// this is the user agent that will be sent to the tracker
|
|
|
|
// when doing requests. It is used to identify the client.
|
|
|
|
// It cannot contain \r or \n
|
|
|
|
std::string user_agent;
|
|
|
|
|
|
|
|
// the number of seconds to wait until giving up on a
|
|
|
|
// tracker request if it hasn't finished
|
|
|
|
int tracker_completion_timeout;
|
|
|
|
|
|
|
|
// the number of seconds where no data is received
|
|
|
|
// from the tracker until it should be considered
|
|
|
|
// as timed out
|
|
|
|
int tracker_receive_timeout;
|
|
|
|
|
|
|
|
// the time to wait when sending a stopped message
|
|
|
|
// before considering a tracker to have timed out.
|
|
|
|
// this is usually shorter, to make the client quit
|
|
|
|
// faster
|
|
|
|
int stop_tracker_timeout;
|
|
|
|
|
|
|
|
// if the content-length is greater than this value
|
|
|
|
// the tracker connection will be aborted
|
|
|
|
int tracker_maximum_response_length;
|
|
|
|
|
2006-04-25 23:04:48 +02:00
|
|
|
// the number of seconds from a request is sent until
|
|
|
|
// it times out if no piece response is returned.
|
|
|
|
int piece_timeout;
|
|
|
|
|
|
|
|
// the length of the request queue given in the number
|
|
|
|
// of seconds it should take for the other end to send
|
|
|
|
// all the pieces. i.e. the actual number of requests
|
|
|
|
// depends on the download rate and this number.
|
|
|
|
float request_queue_time;
|
|
|
|
|
2006-04-30 02:39:18 +02:00
|
|
|
// the number of outstanding block requests a peer is
|
|
|
|
// allowed to queue up in the client. If a peer sends
|
|
|
|
// more requests than this (before the first one has
|
|
|
|
// been sent) the last request will be dropped.
|
|
|
|
// the higher this is, the faster upload speeds the
|
|
|
|
// client can get to a single peer.
|
2006-05-15 00:30:05 +02:00
|
|
|
int max_allowed_in_request_queue;
|
|
|
|
|
|
|
|
// the maximum number of outstanding requests to
|
|
|
|
// send to a peer. This limit takes precedence over
|
|
|
|
// request_queue_time.
|
|
|
|
int max_out_request_queue;
|
2006-05-21 01:24:19 +02:00
|
|
|
|
2006-05-15 00:30:05 +02:00
|
|
|
// if a whole piece can be downloaded in this number
|
|
|
|
// of seconds, or less, the peer_connection will prefer
|
|
|
|
// to request whole pieces at a time from this peer.
|
|
|
|
// The benefit of this is to better utilize disk caches by
|
|
|
|
// doing localized accesses and also to make it easier
|
|
|
|
// to identify bad peers if a piece fails the hash check.
|
|
|
|
int whole_pieces_threshold;
|
2006-06-29 01:27:44 +02:00
|
|
|
|
|
|
|
// the number of seconds to wait for any activity on
|
|
|
|
// the peer wire before closing the connectiong due
|
|
|
|
// to time out.
|
|
|
|
int peer_timeout;
|
|
|
|
|
|
|
|
// same as peer_timeout, but only applies to url-seeds.
|
|
|
|
// this is usually set lower, because web servers are
|
|
|
|
// expected to be more reliable.
|
|
|
|
int urlseed_timeout;
|
2006-08-01 17:27:08 +02:00
|
|
|
|
|
|
|
// controls the pipelining size of url-seeds
|
|
|
|
int urlseed_pipeline_size;
|
2007-11-27 04:37:47 +01:00
|
|
|
|
|
|
|
// time to wait until a new retry takes place
|
|
|
|
int urlseed_wait_retry;
|
2006-11-14 16:53:38 +01:00
|
|
|
|
|
|
|
// sets the upper limit on the total number of files this
|
|
|
|
// session will keep open. The reason why files are
|
|
|
|
// left open at all is that some anti virus software
|
|
|
|
// hooks on every file close, and scans the file for
|
|
|
|
// viruses. deferring the closing of the files will
|
|
|
|
// be the difference between a usable system and
|
|
|
|
// a completely hogged down system. Most operating
|
|
|
|
// systems also has a limit on the total number of
|
|
|
|
// file descriptors a process may have open. It is
|
|
|
|
// usually a good idea to find this limit and set the
|
|
|
|
// number of connections and the number of files
|
|
|
|
// limits so their sum is slightly below it.
|
|
|
|
int file_pool_size;
|
|
|
|
|
|
|
|
// false to not allow multiple connections from the same
|
|
|
|
// IP address. true will allow it.
|
|
|
|
bool allow_multiple_connections_per_ip;
|
2007-02-12 10:20:49 +01:00
|
|
|
|
2007-04-14 23:47:07 +02:00
|
|
|
// the number of times we can fail to connect to a peer
|
|
|
|
// before we stop retrying it.
|
|
|
|
int max_failcount;
|
|
|
|
|
|
|
|
// the number of seconds to wait to reconnect to a peer.
|
|
|
|
// this time is multiplied with the failcount.
|
|
|
|
int min_reconnect_time;
|
|
|
|
|
2007-05-05 02:29:33 +02:00
|
|
|
// this is the timeout for a connection attempt. If
|
|
|
|
// the connect does not succeed within this time, the
|
|
|
|
// connection is dropped. The time is specified in seconds.
|
|
|
|
int peer_connect_timeout;
|
|
|
|
|
2007-05-25 19:06:30 +02:00
|
|
|
// if set to true, upload, download and unchoke limits
|
2007-05-25 23:00:35 +02:00
|
|
|
// are ignored for peers on the local network.
|
2007-05-25 19:06:30 +02:00
|
|
|
bool ignore_limits_on_local_network;
|
|
|
|
|
2007-05-25 23:00:35 +02:00
|
|
|
// the number of connection attempts that
|
|
|
|
// are made per second.
|
|
|
|
int connection_speed;
|
|
|
|
|
2007-05-25 23:19:14 +02:00
|
|
|
// if this is set to true, have messages will be sent
|
|
|
|
// to peers that already have the piece. This is
|
|
|
|
// typically not necessary, but it might be necessary
|
|
|
|
// for collecting statistics in some cases. Default is false.
|
|
|
|
bool send_redundant_have;
|
|
|
|
|
2007-05-27 00:27:40 +02:00
|
|
|
// if this is true, outgoing bitfields will never be fuil. If the
|
|
|
|
// client is seed, a few bits will be set to 0, and later filled
|
|
|
|
// in with have messages. This is to prevent certain ISPs
|
|
|
|
// from stopping people from seeding.
|
|
|
|
bool lazy_bitfields;
|
|
|
|
|
2007-05-31 21:57:15 +02:00
|
|
|
// if a peer is uninteresting and uninterested for longer
|
|
|
|
// than this number of seconds, it will be disconnected.
|
|
|
|
// default is 10 minutes
|
|
|
|
int inactivity_timeout;
|
|
|
|
|
2007-06-08 00:37:58 +02:00
|
|
|
// the number of seconds between chokes/unchokes
|
|
|
|
int unchoke_interval;
|
|
|
|
|
2007-08-16 14:41:46 +02:00
|
|
|
// the number of unchoke intervals between
|
|
|
|
// optimistic unchokes
|
|
|
|
int optimistic_unchoke_multiplier;
|
|
|
|
|
2007-06-13 02:20:06 +02:00
|
|
|
// if this is set, this IP will be reported do the
|
|
|
|
// tracker in the ip= parameter.
|
|
|
|
address announce_ip;
|
|
|
|
|
2007-07-02 20:44:33 +02:00
|
|
|
// the num want sent to trackers
|
|
|
|
int num_want;
|
|
|
|
|
2007-07-07 03:26:30 +02:00
|
|
|
// while we have fewer pieces than this, pick
|
|
|
|
// random pieces instead of rarest first.
|
|
|
|
int initial_picker_threshold;
|
|
|
|
|
2007-08-14 19:47:48 +02:00
|
|
|
// the number of allowed pieces to send to peers
|
|
|
|
// that supports the fast extensions
|
|
|
|
int allowed_fast_set_size;
|
|
|
|
|
2007-08-01 07:22:34 +02:00
|
|
|
// the maximum number of bytes a connection may have
|
|
|
|
// pending in the disk write queue before its download
|
|
|
|
// rate is being throttled. This prevents fast downloads
|
|
|
|
// to slow medias to allocate more and more memory
|
|
|
|
// indefinitely. This should be set to at least 32 kB
|
|
|
|
// to not completely disrupt normal downloads.
|
|
|
|
int max_outstanding_disk_bytes_per_connection;
|
|
|
|
|
2007-10-23 02:19:28 +02:00
|
|
|
// the number of seconds to wait for a handshake
|
|
|
|
// response from a peer. If no response is received
|
|
|
|
// within this time, the peer is disconnected.
|
|
|
|
int handshake_timeout;
|
|
|
|
|
2007-02-12 10:20:49 +01:00
|
|
|
#ifndef TORRENT_DISABLE_DHT
|
|
|
|
// while this is true, the dht will note be used unless the
|
|
|
|
// tracker is online
|
|
|
|
bool use_dht_as_fallback;
|
|
|
|
#endif
|
2007-11-19 05:58:52 +01:00
|
|
|
|
|
|
|
// if this is true, the piece hashes will be freed, in order
|
|
|
|
// to save memory, once the torrent is seeding. This will
|
|
|
|
// make the get_torrent_info() function to return an incomplete
|
|
|
|
// torrent object that cannot be passed back to add_torrent()
|
|
|
|
bool free_torrent_hashes;
|
2008-01-07 06:48:28 +01:00
|
|
|
|
|
|
|
// when this is true, the upnp port mapper will ignore
|
|
|
|
// any upnp devices that don't have an address that matches
|
|
|
|
// our currently configured router.
|
|
|
|
bool upnp_ignore_nonrouters;
|
2008-01-08 02:16:30 +01:00
|
|
|
|
|
|
|
// if the send buffer has fewer bytes than this, we'll
|
|
|
|
// read another 16kB block onto it. If set too small,
|
|
|
|
// upload rate capacity will suffer. If set too high,
|
|
|
|
// memory will be wasted.
|
|
|
|
// The actual watermark may be lower than this in case
|
|
|
|
// the upload rate is low, this is the upper limit.
|
|
|
|
int send_buffer_watermark;
|
2008-01-13 12:18:18 +01:00
|
|
|
|
|
|
|
// if auto_upload_slots is true, and a global upload
|
|
|
|
// limit is set and the upload rate is less than 90%
|
|
|
|
// of the upload limit, on new slot is opened up. If
|
|
|
|
// the upload rate is >= upload limit for an extended
|
|
|
|
// period of time, one upload slot is closed. The
|
|
|
|
// upload slots are never automatically decreased below
|
|
|
|
// the manual settings, through max_uploads.
|
|
|
|
bool auto_upload_slots;
|
2006-08-01 17:27:08 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#ifndef TORRENT_DISABLE_DHT
|
|
|
|
struct dht_settings
|
|
|
|
{
|
|
|
|
dht_settings()
|
|
|
|
: max_peers_reply(50)
|
|
|
|
, search_branching(5)
|
2007-03-15 23:03:56 +01:00
|
|
|
, service_port(0)
|
2006-08-01 17:27:08 +02:00
|
|
|
, max_fail_count(20)
|
|
|
|
{}
|
|
|
|
|
|
|
|
// the maximum number of peers to send in a
|
|
|
|
// reply to get_peers
|
|
|
|
int max_peers_reply;
|
|
|
|
|
|
|
|
// the number of simultanous "connections" when
|
|
|
|
// searching the DHT.
|
|
|
|
int search_branching;
|
|
|
|
|
|
|
|
// the listen port for the dht. This is a UDP port.
|
2007-03-15 23:03:56 +01:00
|
|
|
// zero means use the same as the tcp interface
|
2006-08-01 17:27:08 +02:00
|
|
|
int service_port;
|
|
|
|
|
|
|
|
// the maximum number of times a node can fail
|
|
|
|
// in a row before it is removed from the table.
|
|
|
|
int max_fail_count;
|
2006-04-25 23:04:48 +02:00
|
|
|
};
|
2006-08-01 17:27:08 +02:00
|
|
|
#endif
|
|
|
|
|
2007-06-06 02:41:20 +02:00
|
|
|
#ifndef TORRENT_DISABLE_ENCRYPTION
|
|
|
|
|
|
|
|
struct pe_settings
|
|
|
|
{
|
|
|
|
pe_settings()
|
|
|
|
: out_enc_policy(enabled)
|
|
|
|
, in_enc_policy(enabled)
|
|
|
|
, allowed_enc_level(both)
|
|
|
|
, prefer_rc4(false)
|
|
|
|
{}
|
|
|
|
|
|
|
|
enum enc_policy
|
|
|
|
{
|
|
|
|
forced, // disallow non encrypted connections
|
|
|
|
enabled, // allow encrypted and non encrypted connections
|
|
|
|
disabled // disallow encrypted connections
|
|
|
|
};
|
|
|
|
|
|
|
|
enum enc_level
|
|
|
|
{
|
|
|
|
plaintext, // use only plaintext encryption
|
|
|
|
rc4, // use only rc4 encryption
|
|
|
|
both // allow both
|
|
|
|
};
|
|
|
|
|
|
|
|
enc_policy out_enc_policy;
|
|
|
|
enc_policy in_enc_policy;
|
|
|
|
|
|
|
|
enc_level allowed_enc_level;
|
|
|
|
// if the allowed encryption level is both, setting this to
|
|
|
|
// true will prefer rc4 if both methods are offered, plaintext
|
|
|
|
// otherwise
|
|
|
|
bool prefer_rc4;
|
|
|
|
};
|
|
|
|
#endif
|
|
|
|
|
2006-04-25 23:04:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|