mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-06 22:40:26 -05:00
Merge pull request #170 from Meeeeow/fix_yarn_upstream
Fix upstream search not work with gzip
This commit is contained in:
commit
f4058bb5c2
3 changed files with 19 additions and 9 deletions
|
@ -9,6 +9,7 @@ const parse_interval = require('./config').parse_interval;
|
||||||
const Logger = require('./logger');
|
const Logger = require('./logger');
|
||||||
const MyStreams = require('./streams');
|
const MyStreams = require('./streams');
|
||||||
const Utils = require('./utils');
|
const Utils = require('./utils');
|
||||||
|
const zlib = require('zlib');
|
||||||
const encode = function(thing) {
|
const encode = function(thing) {
|
||||||
return encodeURIComponent(thing).replace(/^%40/, '@');
|
return encodeURIComponent(thing).replace(/^%40/, '@');
|
||||||
};
|
};
|
||||||
|
@ -410,18 +411,27 @@ class Storage {
|
||||||
},
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
|
let parsePackage = (pkg) => {
|
||||||
|
if (Utils.is_object(pkg)) {
|
||||||
|
stream.emit('data', pkg);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
req.on('response', (res) => {
|
req.on('response', (res) => {
|
||||||
if (!String(res.statusCode).match(/^2\d\d$/)) {
|
if (!String(res.statusCode).match(/^2\d\d$/)) {
|
||||||
return stream.emit('error', Error('bad status code ' + res.statusCode + ' from uplink'));
|
return stream.emit('error', Error('bad status code ' + res.statusCode + ' from uplink'));
|
||||||
}
|
}
|
||||||
|
|
||||||
res.pipe(JSONStream.parse('*')).on('data', (pkg) => {
|
// See https://github.com/request/request#requestoptions-callback
|
||||||
if (Utils.is_object(pkg)) {
|
// Request library will not decode gzip stream.
|
||||||
stream.emit('data', pkg);
|
let jsonStream;
|
||||||
|
if (res.headers['content-encoding'] === 'gzip') {
|
||||||
|
jsonStream = res.pipe(zlib.createUnzip());
|
||||||
|
} else {
|
||||||
|
jsonStream = res;
|
||||||
}
|
}
|
||||||
});
|
jsonStream.pipe(JSONStream.parse('*')).on('data', parsePackage);
|
||||||
|
jsonStream.on('end', () => {
|
||||||
res.on('end', () => {
|
|
||||||
stream.emit('end');
|
stream.emit('end');
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
Loading…
Reference in a new issue