mirror of
https://github.com/webtorrent/bittorrent-tracker.git
synced 2025-01-18 20:21:36 +00:00
server: expose getSwarm()
drops capability to pass a *hex* infoHash
This commit is contained in:
parent
fee289b074
commit
aea3c44c08
21
server.js
21
server.js
@ -116,16 +116,9 @@ Server.prototype.close = function (cb) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Server.prototype.getSwarm = function (infoHash) {
|
Server.prototype.getSwarm = function (binaryInfoHash) {
|
||||||
var self = this
|
|
||||||
var binaryInfoHash = Buffer.isBuffer(infoHash)
|
|
||||||
? infoHash.toString('binary')
|
|
||||||
: new Buffer(infoHash, 'hex').toString('binary')
|
|
||||||
return self._getSwarm(binaryInfoHash)
|
|
||||||
}
|
|
||||||
|
|
||||||
Server.prototype._getSwarm = function (binaryInfoHash) {
|
|
||||||
var self = this
|
var self = this
|
||||||
|
if (Buffer.isBuffer(binaryInfoHash)) binaryInfoHash = binaryInfoHash.toString('binary')
|
||||||
var swarm = self.torrents[binaryInfoHash]
|
var swarm = self.torrents[binaryInfoHash]
|
||||||
if (!swarm) {
|
if (!swarm) {
|
||||||
swarm = self.torrents[binaryInfoHash] = {
|
swarm = self.torrents[binaryInfoHash] = {
|
||||||
@ -224,7 +217,7 @@ Server.prototype._onRequest = function (params, cb) {
|
|||||||
Server.prototype._onAnnounce = function (params, cb) {
|
Server.prototype._onAnnounce = function (params, cb) {
|
||||||
var self = this
|
var self = this
|
||||||
|
|
||||||
var swarm = self._getSwarm(params.info_hash)
|
var swarm = self.getSwarm(params.info_hash)
|
||||||
var peer = swarm.peers[params.addr]
|
var peer = swarm.peers[params.addr]
|
||||||
|
|
||||||
var start = function () {
|
var start = function () {
|
||||||
@ -335,7 +328,7 @@ Server.prototype._onScrape = function (params, cb) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
params.info_hash.some(function (infoHash) {
|
params.info_hash.some(function (infoHash) {
|
||||||
var swarm = self._getSwarm(infoHash)
|
var swarm = self.getSwarm(infoHash)
|
||||||
|
|
||||||
response.files[infoHash] = {
|
response.files[infoHash] = {
|
||||||
complete: swarm.complete,
|
complete: swarm.complete,
|
||||||
@ -414,12 +407,14 @@ function parseHttpRequest (req, options) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (params.info_hash) {
|
if (params.info_hash) {
|
||||||
if (!Array.isArray(params.info_hash)) throw new Error('invalid info_hash')
|
if (!Array.isArray(params.info_hash)) throw new Error('invalid info_hash array')
|
||||||
|
|
||||||
params.info_hash.some(function (infoHash) {
|
params.info_hash = params.info_hash.map(function (infoHash) {
|
||||||
if (infoHash.length !== 20) {
|
if (infoHash.length !== 20) {
|
||||||
throw new Error('invalid info_hash')
|
throw new Error('invalid info_hash')
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return infoHash
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -2,7 +2,7 @@ var Client = require('../')
|
|||||||
var Server = require('../').Server
|
var Server = require('../').Server
|
||||||
var test = require('tape')
|
var test = require('tape')
|
||||||
|
|
||||||
var infoHash = '4cb67059ed6bd08362da625b3ae77f6f4a075705'
|
var infoHash = new Buffer('4cb67059ed6bd08362da625b3ae77f6f4a075705', 'hex')
|
||||||
var peerId = '01234567890123456789'
|
var peerId = '01234567890123456789'
|
||||||
var peerId2 = '12345678901234567890'
|
var peerId2 = '12345678901234567890'
|
||||||
var torrentLength = 50000
|
var torrentLength = 50000
|
||||||
|
Loading…
Reference in New Issue
Block a user