|
1 | 1 | var async = require('async');
|
2 | 2 | var chalk = require('chalk');
|
3 | 3 | var fs = require('fs-extra');
|
4 |
| -var request = require('request'); |
5 | 4 | var tildify = require('tildify');
|
6 |
| -var ProgressBar = require('progress'); |
7 | 5 | var figures = require('figures');
|
8 |
| -var format = require('util').format; |
9 | 6 | var debug = require('debug')('mongodb-version-manager:download');
|
10 |
| - |
11 |
| -function progressbar(pkg, res, totalSize) { |
12 |
| - var bar = new ProgressBar(' Downloading MongoDB v' |
13 |
| - + pkg.version + ' [:bar] :percent :etasec', { |
14 |
| - complete: '=', |
15 |
| - incomplete: ' ', |
16 |
| - width: 40, |
17 |
| - total: totalSize |
18 |
| - }); |
19 |
| - |
20 |
| - res.on('data', function(chunk) { |
21 |
| - bar.tick(chunk.length); |
22 |
| - }); |
23 |
| -} |
| 7 | +var nugget = require('nugget'); |
24 | 8 |
|
25 | 9 | function download(model, done) {
|
26 | 10 | debug('downloading artifact from `%s` to `%s`...',
|
27 | 11 | model.url, tildify(model.download_path));
|
28 | 12 |
|
29 |
| - var out = fs.createWriteStream(model.download_path); |
30 |
| - var onFinish; |
31 |
| - var onError = function(err) { |
32 |
| - out.removeListener('finish', onFinish); |
33 |
| - debug('removing incomplete artifact from `%s`', |
34 |
| - model.download_path); |
35 |
| - fs.unlink(model.download_path, function() { |
36 |
| - done(err); |
37 |
| - }); |
38 |
| - }; |
39 |
| - |
40 |
| - onFinish = function() { |
41 |
| - /* eslint no-console:0 */ |
42 |
| - out.removeListener('error', onError); |
| 13 | + var quiet = process.env.silent; |
| 14 | + var verbose = process.env.VERBOSE; |
| 15 | + var nuggetOpts = {target: model.filename, dir: model.download_directory, resume: true, verbose: verbose, quiet: quiet}; |
| 16 | + nugget(model.url, nuggetOpts, function(errors) { |
| 17 | + if (errors) { |
| 18 | + var error = errors[0]; // nugget returns an array of errors but we only need 1st because we only have 1 url |
| 19 | + debug('removing incomplete artifact from `%s`', |
| 20 | + model.download_path); |
| 21 | + fs.unlink(model.download_path, function() { |
| 22 | + done(error); |
| 23 | + }); |
| 24 | + return; |
| 25 | + } |
43 | 26 | debug('successfully downloaded MongoDB version v%s to %s',
|
44 | 27 | model.version, model.download_path);
|
45 | 28 | if (!process.env.silent) {
|
46 | 29 | console.log(chalk.bold.green(figures.tick),
|
47 | 30 | ' Downloaded MongoDB', model.version);
|
48 | 31 | }
|
49 | 32 | done();
|
50 |
| - }; |
51 |
| - out.once('error', onError).once('finish', onFinish); |
52 |
| - |
53 |
| - var req = request(model.url); |
54 |
| - req.on('response', function(res) { |
55 |
| - var totalSize = parseInt(res.headers['content-length'], 10); |
56 |
| - debug('total size %dMB', (totalSize / 1024 / 1024).toFixed(2)); |
57 |
| - |
58 |
| - if (!totalSize || totalSize < 10 * 1024 * 1024) { |
59 |
| - var msg = format('Download looks too small! %s is only %s bytes!', |
60 |
| - model.url, totalSize); |
61 |
| - return onError(new Error(msg)); |
62 |
| - } |
63 |
| - |
64 |
| - if (process.env.silent) { |
65 |
| - debug('Downloading `%s`...', model.url); |
66 |
| - } else if (!process.env.CI) { |
67 |
| - progressbar(model, res, totalSize); |
68 |
| - } else { |
69 |
| - console.log('Downloading `%s`...', model.url); |
70 |
| - } |
71 |
| - }); |
72 |
| - req.pipe(out); |
73 |
| - req.on('error', function(err) { |
74 |
| - onError(err); |
75 | 33 | });
|
76 | 34 | }
|
77 | 35 |
|
|
0 commit comments