bt-tracker-client

0.0.3 • Public • Published

bt-tracker-client travis npm downloads javascript style guide

Simple, robust, BitTorrent tracker (client) implementation

Node.js implementation of a BitTorrent tracker, client and server.

A BitTorrent tracker is a web service which responds to requests from BitTorrent clients. The requests include metrics from clients that help the tracker keep overall statistics about the torrent. The response includes a peer list that helps the client participate in the torrent swarm.

features

  • Includes client implementations
  • Supports all mainstream tracker types:
  • Supports ipv4 & ipv6
  • Supports tracker "scrape" extension
  • Robust and well-tested

Also see bittorrent-dht.

install

npm install bt-tracker-client

usage

client

To connect to a tracker, just do this:

var Client = require('bt-tracker-client')
 
var requiredOpts = {
  infoHash: new Buffer('012345678901234567890'), // hex string or Buffer
  peerId: new Buffer('01234567890123456789'), // hex string or Buffer
  announce: [], // list of tracker server urls
  port: 6881 // torrent client port, (in browser, optional)
}
 
var optionalOpts = {
  getAnnounceOpts: function () {
    // Provide a callback that will be called whenever announce() is called
    // internally (on timer), or by the user
    return {
      uploaded: 0,
      downloaded: 0,
      left: 0,
      customParam: 'blah' // custom parameters supported
    }
  },
  // RTCPeerConnection config object (only used in browser)
  rtcConfig: {},
  // User-Agent header for http requests
  userAgent: '',
  // Custom webrtc impl, useful in node to specify [wrtc](https://npmjs.com/package/wrtc)
  wrtc: {},
}
 
var client = new Client(requiredOpts)
 
client.on('error', function (err) {
  // fatal client error!
  console.log(err.message)
})
 
client.on('warning', function (err) {
  // a tracker was unavailable or sent bad data to the client. you can probably ignore it
  console.log(err.message)
})
 
// start getting peers from the tracker
client.start()
 
client.on('update', function (data) {
  console.log('got an announce response from tracker: ' + data.announce)
  console.log('number of seeders in the swarm: ' + data.complete)
  console.log('number of leechers in the swarm: ' + data.incomplete)
})
 
client.once('peer', function (addr) {
  console.log('found a peer: ' + addr) // 85.10.239.191:48623
})
 
// announce that download has completed (and you are now a seeder)
client.complete()
 
// force a tracker announce. will trigger more 'update' events and maybe more 'peer' events
client.update()
 
// provide parameters to the tracker
client.update({
  uploaded: 0,
  downloaded: 0,
  left: 0,
  customParam: 'blah' // custom parameters supported
})
 
// stop getting peers from the tracker, gracefully leave the swarm
client.stop()
 
// ungracefully leave the swarm (without sending final 'stop' message)
client.destroy()
 
// scrape
client.scrape()
 
client.on('scrape', function (data) {
  console.log('got a scrape response from tracker: ' + data.announce)
  console.log('number of seeders in the swarm: ' + data.complete)
  console.log('number of leechers in the swarm: ' + data.incomplete)
  console.log('number of total downloads of this torrent: ' + data.downloaded)
})

multi scrape

Scraping multiple torrent info is possible with a static Client.scrape method:

var Client = require('bt-tracker-client')
Client.scrape({ announce: announceUrl, infoHash: [ infoHash1, infoHash2 ]}, function (err, results) {
  results[infoHash1].announce
  results[infoHash1].infoHash
  results[infoHash1].complete
  results[infoHash1].incomplete
  results[infoHash1].downloaded
 
  // ...
})

license

MIT. Copyright (c) Feross Aboukhadijeh and WebTorrent, LLC.

Package Sidebar

Install

npm i bt-tracker-client

Weekly Downloads

1

Version

0.0.3

License

MIT

Unpacked Size

41.7 kB

Total Files

11

Last publish

Collaborators

  • allex