Merge pull request #55 from n1t0/master

[Client] Add https support
This commit is contained in:
Feross Aboukhadijeh 2015-01-22 14:11:04 -08:00
commit 255395e215

View File

@ -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))