2008-06-07 21:26:41 +00:00
|
|
|
/*
|
2014-01-19 01:09:44 +00:00
|
|
|
* This file Copyright (C) 2008-2014 Mnemosyne LLC
|
2008-06-07 21:26:41 +00:00
|
|
|
*
|
2014-01-21 03:10:30 +00:00
|
|
|
* It may be used under the GNU GPL versions 2 or 3
|
2014-01-19 01:09:44 +00:00
|
|
|
* or any future license endorsed by Mnemosyne LLC.
|
2008-06-07 21:26:41 +00:00
|
|
|
*
|
|
|
|
* $Id$
|
|
|
|
*/
|
2008-11-24 20:17:36 +00:00
|
|
|
|
|
|
|
#ifndef __TRANSMISSION__
|
2010-05-26 15:23:21 +00:00
|
|
|
#error only libtransmission should #include this header.
|
2008-11-24 20:17:36 +00:00
|
|
|
#endif
|
2008-06-07 21:26:41 +00:00
|
|
|
|
|
|
|
#ifndef TR_PEER_H
|
|
|
|
#define TR_PEER_H
|
|
|
|
|
|
|
|
#include "transmission.h"
|
2013-02-03 22:40:00 +00:00
|
|
|
#include "bitfield.h"
|
|
|
|
#include "history.h"
|
|
|
|
#include "quark.h"
|
2011-02-17 05:14:53 +00:00
|
|
|
|
2013-02-03 23:29:34 +00:00
|
|
|
/**
|
|
|
|
* @addtogroup peers Peers
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2013-02-04 16:23:33 +00:00
|
|
|
struct tr_peer;
|
|
|
|
struct tr_swarm;
|
|
|
|
|
2009-11-08 23:20:00 +00:00
|
|
|
enum
|
|
|
|
{
|
2013-02-02 20:17:52 +00:00
|
|
|
/* this is the maximum size of a block request.
|
|
|
|
most bittorrent clients will reject requests
|
|
|
|
larger than this size. */
|
|
|
|
MAX_BLOCK_SIZE = (1024 * 16)
|
2009-11-08 23:20:00 +00:00
|
|
|
};
|
|
|
|
|
2008-06-07 21:26:41 +00:00
|
|
|
/**
|
|
|
|
*** Peer Publish / Subscribe
|
|
|
|
**/
|
|
|
|
|
|
|
|
typedef enum
|
|
|
|
{
|
2013-02-02 20:17:52 +00:00
|
|
|
TR_PEER_CLIENT_GOT_BLOCK,
|
|
|
|
TR_PEER_CLIENT_GOT_CHOKE,
|
|
|
|
TR_PEER_CLIENT_GOT_PIECE_DATA,
|
|
|
|
TR_PEER_CLIENT_GOT_ALLOWED_FAST,
|
|
|
|
TR_PEER_CLIENT_GOT_SUGGEST,
|
|
|
|
TR_PEER_CLIENT_GOT_PORT,
|
|
|
|
TR_PEER_CLIENT_GOT_REJ,
|
|
|
|
TR_PEER_CLIENT_GOT_BITFIELD,
|
|
|
|
TR_PEER_CLIENT_GOT_HAVE,
|
|
|
|
TR_PEER_CLIENT_GOT_HAVE_ALL,
|
|
|
|
TR_PEER_CLIENT_GOT_HAVE_NONE,
|
|
|
|
TR_PEER_PEER_GOT_PIECE_DATA,
|
|
|
|
TR_PEER_ERROR
|
2008-06-07 21:26:41 +00:00
|
|
|
}
|
|
|
|
PeerEventType;
|
|
|
|
|
|
|
|
typedef struct
|
|
|
|
{
|
2013-02-02 20:17:52 +00:00
|
|
|
PeerEventType eventType;
|
|
|
|
|
|
|
|
uint32_t pieceIndex; /* for GOT_BLOCK, GOT_HAVE, CANCEL, ALLOWED, SUGGEST */
|
|
|
|
struct tr_bitfield * bitfield; /* for GOT_BITFIELD */
|
|
|
|
uint32_t offset; /* for GOT_BLOCK */
|
|
|
|
uint32_t length; /* for GOT_BLOCK + GOT_PIECE_DATA */
|
|
|
|
int err; /* errno for GOT_ERROR */
|
|
|
|
tr_port port; /* for GOT_PORT */
|
2008-06-07 21:26:41 +00:00
|
|
|
}
|
|
|
|
tr_peer_event;
|
|
|
|
|
2011-02-17 05:14:53 +00:00
|
|
|
extern const tr_peer_event TR_PEER_EVENT_INIT;
|
|
|
|
|
2013-09-08 17:08:18 +00:00
|
|
|
typedef void (*tr_peer_callback) (struct tr_peer * peer,
|
|
|
|
const tr_peer_event * event,
|
|
|
|
void * client_data);
|
2013-02-04 16:23:33 +00:00
|
|
|
|
|
|
|
/***
|
|
|
|
****
|
|
|
|
***/
|
|
|
|
|
|
|
|
typedef void (*tr_peer_destruct_func)(struct tr_peer * peer);
|
|
|
|
typedef bool (*tr_peer_is_transferring_pieces_func)(const struct tr_peer * peer,
|
|
|
|
uint64_t now,
|
|
|
|
tr_direction direction,
|
|
|
|
unsigned int * Bps);
|
|
|
|
struct tr_peer_virtual_funcs
|
|
|
|
{
|
|
|
|
tr_peer_destruct_func destruct;
|
|
|
|
tr_peer_is_transferring_pieces_func is_transferring_pieces;
|
|
|
|
};
|
|
|
|
|
2013-02-03 22:40:00 +00:00
|
|
|
/**
|
|
|
|
* State information about a connected peer.
|
|
|
|
*
|
|
|
|
* @see struct peer_atom
|
2013-02-04 16:23:33 +00:00
|
|
|
* @see tr_peerMsgs
|
2013-02-03 22:40:00 +00:00
|
|
|
*/
|
|
|
|
typedef struct tr_peer
|
|
|
|
{
|
|
|
|
/* whether or not we should free this peer soon.
|
|
|
|
NOTE: private to peer-mgr.c */
|
|
|
|
bool doPurge;
|
|
|
|
|
|
|
|
/* number of bad pieces they've contributed to */
|
|
|
|
uint8_t strikes;
|
|
|
|
|
|
|
|
/* how many requests the peer has made that we haven't responded to yet */
|
|
|
|
int pendingReqsToClient;
|
|
|
|
|
|
|
|
/* how many requests we've made and are currently awaiting a response for */
|
|
|
|
int pendingReqsToPeer;
|
|
|
|
|
2013-02-03 22:45:32 +00:00
|
|
|
/* Hook to private peer-mgr information */
|
2013-02-03 22:40:00 +00:00
|
|
|
struct peer_atom * atom;
|
|
|
|
|
2013-02-04 16:23:33 +00:00
|
|
|
struct tr_swarm * swarm;
|
|
|
|
|
2013-02-03 22:40:00 +00:00
|
|
|
/** how complete the peer's copy of the torrent is. [0.0...1.0] */
|
|
|
|
float progress;
|
|
|
|
|
|
|
|
struct tr_bitfield blame;
|
|
|
|
struct tr_bitfield have;
|
|
|
|
|
|
|
|
/* the client name.
|
|
|
|
For BitTorrent peers, this is the app name derived from the `v' string in LTEP's handshake dictionary */
|
|
|
|
tr_quark client;
|
|
|
|
|
|
|
|
tr_recentHistory blocksSentToClient;
|
|
|
|
tr_recentHistory blocksSentToPeer;
|
|
|
|
|
|
|
|
tr_recentHistory cancelsSentToClient;
|
|
|
|
tr_recentHistory cancelsSentToPeer;
|
|
|
|
|
2013-02-04 16:23:33 +00:00
|
|
|
const struct tr_peer_virtual_funcs * funcs;
|
2013-02-03 22:40:00 +00:00
|
|
|
}
|
|
|
|
tr_peer;
|
2010-06-19 14:33:10 +00:00
|
|
|
|
2013-02-04 16:23:33 +00:00
|
|
|
|
|
|
|
void tr_peerConstruct (struct tr_peer * peer, const tr_torrent * tor);
|
|
|
|
|
|
|
|
void tr_peerDestruct (struct tr_peer * peer);
|
|
|
|
|
2010-06-19 14:33:10 +00:00
|
|
|
|
2011-02-24 14:35:45 +00:00
|
|
|
/** Update the tr_peer.progress field based on the 'have' bitset. */
|
2012-12-05 17:29:46 +00:00
|
|
|
void tr_peerUpdateProgress (tr_torrent * tor, struct tr_peer *);
|
2011-02-24 14:35:45 +00:00
|
|
|
|
2013-07-08 16:41:12 +00:00
|
|
|
bool tr_peerIsSeed (const struct tr_peer * peer);
|
|
|
|
|
|
|
|
/***
|
|
|
|
****
|
|
|
|
***/
|
|
|
|
|
|
|
|
typedef struct tr_swarm_stats
|
|
|
|
{
|
|
|
|
int activePeerCount[2];
|
|
|
|
int activeWebseedCount;
|
|
|
|
int peerCount;
|
|
|
|
int peerFromCount[TR_PEER_FROM__MAX];
|
|
|
|
}
|
|
|
|
tr_swarm_stats;
|
|
|
|
|
|
|
|
extern const tr_swarm_stats TR_SWARM_STATS_INIT;
|
|
|
|
|
|
|
|
void tr_swarmGetStats (const struct tr_swarm * swarm, tr_swarm_stats * setme);
|
|
|
|
|
|
|
|
void tr_swarmIncrementActivePeers (struct tr_swarm * swarm, tr_direction direction, bool is_active);
|
|
|
|
|
|
|
|
|
|
|
|
/***
|
|
|
|
****
|
|
|
|
***/
|
|
|
|
|
2011-02-24 14:35:45 +00:00
|
|
|
|
2014-07-04 00:00:07 +00:00
|
|
|
#ifdef _WIN32
|
2014-12-13 15:22:39 +00:00
|
|
|
#undef EMSGSIZE
|
2009-08-12 14:40:32 +00:00
|
|
|
#define EMSGSIZE WSAEMSGSIZE
|
2008-10-10 00:38:37 +00:00
|
|
|
#endif
|
|
|
|
|
2009-05-29 19:17:12 +00:00
|
|
|
/** @} */
|
|
|
|
|
2008-06-07 21:26:41 +00:00
|
|
|
#endif
|