transmission/libtransmission/session.h

244 lines
7.0 KiB
C
Raw Normal View History

/*
2010-01-04 21:00:47 +00:00
* This file Copyright (C) 2008-2010 Mnemosyne LLC
2006-07-16 19:39:23 +00:00
*
* This file is licensed by the GPL version 2. Works owned by the
* Transmission project are granted a special exemption to clause 2(b)
* so that the bulk of its code can remain under the MIT license.
* This exemption does not extend to derived works not owned by
* the Transmission project.
2006-07-16 19:39:23 +00:00
*
* $Id$
*/
2006-07-16 19:39:23 +00:00
#ifndef __TRANSMISSION__
#error only libtransmission should #include this header.
#endif
2006-07-16 19:39:23 +00:00
#ifndef TR_INTERNAL_H
#define TR_INTERNAL_H 1
#define TR_NAME "Transmission"
2007-03-23 08:28:01 +00:00
#ifndef UNUSED
#ifdef __GNUC__
#define UNUSED __attribute__ ( ( unused ) )
#else
#define UNUSED
#endif
#endif
#include "bencode.h"
2008-05-18 16:44:30 +00:00
typedef enum { TR_NET_OK, TR_NET_ERROR, TR_NET_WAIT } tr_tristate_t;
uint8_t* tr_peerIdNew( void );
2008-01-07 06:19:34 +00:00
const uint8_t* tr_getPeerId( void );
struct tr_address;
struct tr_announcer;
struct tr_bandwidth;
struct tr_bindsockets;
struct tr_fdInfo;
2008-11-06 02:56:51 +00:00
/**
* How clock mode works:
*
* ._nextChangeAt, ._nextChangeValue and ._nextChangeAllowed are private fields
* that are derived from .days, .beginMinute, .endMinute and the current time.
* They're rebuilt when either (a) the user changes the clock settings or
* (b) when the time at ._nextChangeAt is reached.
*
* When ._nextChangeAt is reached, if .isClockEnabled and ._nextChangeAllowed
* are both true, then turtle mode's flag is set to ._nextChangeValue.
*/
struct tr_turtle_info
{
/* TR_UP and TR_DOWN speed limits */
int speedLimit[2];
/* is turtle mode on right now? */
tr_bool isEnabled;
/* does turtle mode turn itself on and off at given times? */
tr_bool isClockEnabled;
/* when clock mode is on, minutes after midnight to turn on turtle mode */
int beginMinute;
/* when clock mode is on, minutes after midnight to turn off turtle mode */
int endMinute;
/* only use clock mode on these days of the week */
tr_sched_day days;
/* called when isEnabled changes */
tr_altSpeedFunc * callback;
/* the callback's user_data argument */
void * callbackUserData;
/* the callback's changedByUser argument.
* indicates whether the change came from the user or from the clock. */
tr_bool changedByUser;
/* this is the next time the clock will set turtle mode */
time_t _nextChangeAt;
/* the clock will set turtle mode to this flag. */
tr_bool _nextChangeValue;
/* When clock mode is on, only toggle turtle mode if this is true.
* This flag is used to filter out changes that fall on days when
* clock mode is disabled. */
tr_bool _nextChangeAllowed;
/* The last time the clock tested to see if _nextChangeAt was reached */
time_t testedAt;
};
/** @brief handle to an active libtransmission session */
struct tr_session
2006-07-16 19:39:23 +00:00
{
tr_bool isPortRandom;
tr_bool isPexEnabled;
tr_bool isDHTEnabled;
tr_bool isBlocklistEnabled;
tr_bool isProxyEnabled;
tr_bool isProxyAuthEnabled;
tr_bool isClosed;
tr_bool useLazyBitfield;
tr_bool isIncompleteFileNamingEnabled;
tr_bool isRatioLimited;
tr_bool isIncompleteDirEnabled;
tr_benc removedTorrents;
int umask;
int speedLimit[2];
2009-03-28 16:47:01 +00:00
tr_bool speedLimitEnabled[2];
struct tr_turtle_info turtle;
struct tr_fdInfo * fdInfo;
int magicNumber;
tr_encryption_mode encryptionMode;
tr_preallocation_mode preallocationMode;
struct tr_event_handle * events;
uint16_t peerLimitPerTorrent;
int uploadSlotsPerTorrent;
tr_port peerPort;
tr_port randomPortLow;
tr_port randomPortHigh;
int proxyPort;
int peerSocketTOS;
int torrentCount;
tr_torrent * torrentList;
2008-04-12 00:29:49 +00:00
char * tag;
char * configDir;
char * downloadDir;
char * resumeDir;
char * torrentDir;
char * incompleteDir;
tr_proxy_type proxyType;
char * proxy;
char * proxyUsername;
char * proxyPassword;
2008-06-10 16:16:31 +00:00
struct tr_list * blocklists;
struct tr_peerMgr * peerMgr;
struct tr_shared * shared;
struct tr_lock * lock;
2006-07-16 19:39:23 +00:00
struct tr_web * web;
struct tr_rpc_server * rpcServer;
tr_rpc_func rpc_func;
void * rpc_func_user_data;
2008-05-18 16:44:30 +00:00
struct tr_stats_handle * sessionStats;
struct tr_announcer * announcer;
tr_benc * metainfoLookup;
2008-11-06 02:56:51 +00:00
struct event * nowTimer;
struct event * saveTimer;
/* monitors the "global pool" speeds */
struct tr_bandwidth * bandwidth;
double desiredRatio;
struct tr_bindinfo * public_ipv4;
struct tr_bindinfo * public_ipv6;
2006-07-16 19:39:23 +00:00
};
tr_bool tr_sessionAllowsDHT( const tr_session * session );
const char * tr_sessionFindTorrentFile( const tr_session * session,
const char * hashString );
void tr_sessionSetTorrentFile( tr_session * session,
const char * hashString,
const char * filename );
2008-12-03 07:10:09 +00:00
tr_bool tr_sessionIsAddressBlocked( const tr_session * session,
const struct tr_address * addr );
void tr_sessionLock( tr_session * );
void tr_sessionUnlock( tr_session * );
tr_bool tr_sessionIsLocked( const tr_session * );
const struct tr_address* tr_sessionGetPublicAddress( const tr_session *, int tr_af_type );
struct tr_bindsockets * tr_sessionGetBindSockets( tr_session * );
enum
{
SESSION_MAGIC_NUMBER = 3845
};
static inline tr_bool tr_isSession( const tr_session * session )
{
return ( session != NULL ) && ( session->magicNumber == SESSION_MAGIC_NUMBER );
}
static inline tr_bool tr_isPreallocationMode( tr_preallocation_mode m )
{
return ( m == TR_PREALLOCATE_NONE )
|| ( m == TR_PREALLOCATE_SPARSE )
|| ( m == TR_PREALLOCATE_FULL );
}
static inline tr_bool tr_isEncryptionMode( tr_encryption_mode m )
{
return ( m == TR_CLEAR_PREFERRED )
|| ( m == TR_ENCRYPTION_PREFERRED )
|| ( m == TR_ENCRYPTION_REQUIRED );
}
static inline tr_bool tr_isPriority( tr_priority_t p )
{
return ( p == TR_PRI_LOW )
|| ( p == TR_PRI_NORMAL )
|| ( p == TR_PRI_HIGH );
}
2006-07-16 19:39:23 +00:00
#endif