Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/webtorrent/webtorrent.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--index.js57
-rw-r--r--package.json2
2 files changed, 20 insertions, 39 deletions
diff --git a/index.js b/index.js
index d342455..403c026 100644
--- a/index.js
+++ b/index.js
@@ -186,7 +186,7 @@ WebTorrent.prototype.download = function (torrentId, opts, ontorrent) {
* - W3C FileList object (basically an array of `File` objects)
* - Array of `File` objects
*
- * @param {string|File|FileList|Blob|Buffer|Array.<File|Blob|Buffer>} input
+ * @param {string|File|FileList|Buffer|Array.<File|Buffer>} input
* @param {Object} opts
* @param {function} onseed
*/
@@ -199,45 +199,26 @@ WebTorrent.prototype.seed = function (input, opts, onseed) {
if (!opts) opts = {}
// TODO: support an array of paths
- // TODO: support path to folder (currently, only path to file supported)
-
- if (typeof FileList !== 'undefined' && input instanceof FileList)
- input = Array.prototype.slice.call(input)
-
- if (isBlob(input) || Buffer.isBuffer(input))
- input = [ input ]
-
- var streams
- if (Array.isArray(input) && input.length > 0) {
- streams = input.map(function (item) {
- if (isBlob(item)) return new FileReadStream(item)
- else if (Buffer.isBuffer(item)) {
- var s = new stream.PassThrough()
- s.end(item)
- return s
- } else {
- throw new Error('Array must contain only File|Blob|Buffer objects')
- }
- })
- } else if (typeof input === 'string') {
- streams = [ fs.createReadStream(input) ]
- } else {
- throw new Error('invalid input type')
- }
- createTorrent(input, opts, function (err, torrentBuf) {
+ createTorrent.parseInput(input, opts, function (err, files) {
if (err) return self.emit('error', err)
- self.add(torrentBuf, opts, function (torrent) {
- var tasks = [function (cb) {
- torrent.storage.load(streams, cb)
- }]
- if (self.dht) tasks.push(function (cb) {
- torrent.on('dhtAnnounce', cb)
- })
- parallel(tasks, function (err) {
- if (err) return self.emit('error', err)
- if (onseed) onseed(torrent)
- self.emit('seed', torrent)
+ var streams = files.map(function (file) { return file.getStream })
+
+ createTorrent(input, opts, function (err, torrentBuf) {
+ if (err) return self.emit('error', err)
+
+ self.add(torrentBuf, opts, function (torrent) {
+ var tasks = [function (cb) {
+ torrent.storage.load(streams, cb)
+ }]
+ if (self.dht) tasks.push(function (cb) {
+ torrent.on('dhtAnnounce', cb)
+ })
+ parallel(tasks, function (err) {
+ if (err) return self.emit('error', err)
+ if (onseed) onseed(torrent)
+ self.emit('seed', torrent)
+ })
})
})
})
diff --git a/package.json b/package.json
index 5444d89..a8af1e4 100644
--- a/package.json
+++ b/package.json
@@ -32,7 +32,7 @@
"block-stream": "0.0.7",
"clivas": "^0.1.4",
"concat-stream": "^1.4.6",
- "create-torrent": "^3.1.0",
+ "create-torrent": "^3.4.0",
"debug": "^2.1.0",
"dezalgo": "^1.0.1",
"end-of-stream": "^1.0.0",