mirror of
https://github.com/webtorrent/bittorrent-tracker.git
synced 2025-01-19 04:31:36 +00:00
commit
255395e215
12
client.js
12
client.js
@ -11,6 +11,7 @@ var EventEmitter = require('events').EventEmitter
|
|||||||
var extend = require('extend.js')
|
var extend = require('extend.js')
|
||||||
var hat = require('hat')
|
var hat = require('hat')
|
||||||
var http = require('http')
|
var http = require('http')
|
||||||
|
var https = require('https')
|
||||||
var inherits = require('inherits')
|
var inherits = require('inherits')
|
||||||
var once = require('once')
|
var once = require('once')
|
||||||
var url = require('url')
|
var url = require('url')
|
||||||
@ -52,7 +53,8 @@ function Client (peerId, port, torrent, opts) {
|
|||||||
if (typeof torrent.announce === 'string') torrent.announce = [ torrent.announce ]
|
if (typeof torrent.announce === 'string') torrent.announce = [ torrent.announce ]
|
||||||
self._trackers = (torrent.announce || [])
|
self._trackers = (torrent.announce || [])
|
||||||
.filter(function (announceUrl) {
|
.filter(function (announceUrl) {
|
||||||
return announceUrl.indexOf('udp://') === 0 || announceUrl.indexOf('http://') === 0
|
var protocol = url.parse(announceUrl).protocol
|
||||||
|
return protocol === 'udp:' || protocol === 'http:' || protocol === 'https:'
|
||||||
})
|
})
|
||||||
.map(function (announceUrl) {
|
.map(function (announceUrl) {
|
||||||
return new Tracker(self, announceUrl, self._opts)
|
return new Tracker(self, announceUrl, self._opts)
|
||||||
@ -150,9 +152,10 @@ function Tracker (client, announceUrl, opts) {
|
|||||||
self._intervalMs = self.client._intervalMs // use client interval initially
|
self._intervalMs = self.client._intervalMs // use client interval initially
|
||||||
self._interval = null
|
self._interval = null
|
||||||
|
|
||||||
if (self._announceUrl.indexOf('udp://') === 0) {
|
var protocol = url.parse(self._announceUrl).protocol
|
||||||
|
if (protocol === 'udp:') {
|
||||||
self._requestImpl = self._requestUdp
|
self._requestImpl = self._requestUdp
|
||||||
} else if (self._announceUrl.indexOf('http://') === 0) {
|
} else if (protocol === 'http:' || protocol === 'https:') {
|
||||||
self._requestImpl = self._requestHttp
|
self._requestImpl = self._requestHttp
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -265,9 +268,10 @@ Tracker.prototype._requestHttp = function (requestUrl, opts) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
var protocol = url.parse(self._announceUrl).protocol
|
||||||
var fullUrl = requestUrl + '?' + common.querystringStringify(opts)
|
var fullUrl = requestUrl + '?' + common.querystringStringify(opts)
|
||||||
|
|
||||||
var req = http.get(fullUrl, function (res) {
|
var req = (protocol === 'https:' ? https : http).get(fullUrl, function (res) {
|
||||||
if (res.statusCode !== 200) {
|
if (res.statusCode !== 200) {
|
||||||
res.resume() // consume the whole stream
|
res.resume() // consume the whole stream
|
||||||
self.client.emit('warning', new Error('Invalid response code ' + res.statusCode + ' from tracker ' + requestUrl))
|
self.client.emit('warning', new Error('Invalid response code ' + res.statusCode + ' from tracker ' + requestUrl))
|
||||||
|
Loading…
Reference in New Issue
Block a user