0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2025-01-06 22:40:26 -05:00

Fix #73 Refactor Storage methods affected

This commit is contained in:
Juan Picado @jotadeveloper 2017-06-22 22:35:09 +02:00
parent 2d4f1b2362
commit 9fdc251b83
No known key found for this signature in database
GPG key ID: 18AC54485952D158
2 changed files with 67 additions and 62 deletions

View file

@ -366,7 +366,9 @@ class Storage {
if (err) return callback(err);
const whitelist = ['_rev', 'name', 'versions', 'dist-tags', 'readme'];
for (let i in result) {
if (whitelist.indexOf(i) === -1) delete result[i];
if (whitelist.indexOf(i) === -1) {
delete result[i];
}
}
Utils.normalize_dist_tags(result);
@ -477,17 +479,17 @@ class Storage {
if package is available locally, it MUST be provided in pkginfo
returns callback(err, result, uplink_errors)
* @param {*} name
* @param {*} pkginfo
* @param {*} packageInfo
* @param {*} options
* @param {*} callback
*/
_sync_package_with_uplinks(name, pkginfo, options, callback) {
_sync_package_with_uplinks(name, packageInfo, options, callback) {
let self = this;
let exists = false;
if (!pkginfo) {
if (!packageInfo) {
exists = false;
pkginfo = {
packageInfo = {
'name': name,
'versions': {},
'dist-tags': {},
@ -497,35 +499,35 @@ class Storage {
exists = true;
}
let uplinks = [];
let upLinks = [];
for (let i in self.uplinks) {
if (self.config.hasProxyTo(name, i)) {
uplinks.push(self.uplinks[i]);
upLinks.push(self.uplinks[i]);
}
}
async.map(uplinks, function(up, cb) {
async.map(upLinks, function(up, cb) {
let _options = Object.assign({}, options);
if (Utils.is_object(pkginfo._uplinks[up.upname])) {
let fetched = pkginfo._uplinks[up.upname].fetched;
if (Utils.is_object(packageInfo._uplinks[up.upname])) {
let fetched = packageInfo._uplinks[up.upname].fetched;
if (fetched && fetched > (Date.now() - up.maxage)) {
return cb();
}
_options.etag = pkginfo._uplinks[up.upname].etag;
_options.etag = packageInfo._uplinks[up.upname].etag;
}
up.getRemotePackage(name, _options, function(err, up_res, etag) {
up.getRemotePackage(name, _options, function(err, upLinkResponse, etag) {
if (err && err.status === 304) {
pkginfo._uplinks[up.upname].fetched = Date.now();
packageInfo._uplinks[up.upname].fetched = Date.now();
}
if (err || !up_res) {
if (err || !upLinkResponse) {
return cb(null, [err || Error('no data')]);
}
try {
Utils.validate_metadata(up_res, name);
Utils.validate_metadata(upLinkResponse, name);
} catch(err) {
self.logger.error({
sub: 'out',
@ -534,15 +536,16 @@ class Storage {
return cb(null, [err]);
}
pkginfo._uplinks[up.upname] = {
packageInfo._uplinks[up.upname] = {
etag: etag,
fetched: Date.now(),
};
for (let i in up_res.versions) {
if (Object.prototype.hasOwnProperty.call(up_res.versions, i)) {
for (let i in upLinkResponse.versions) {
if (Object.prototype.hasOwnProperty.call(upLinkResponse.versions, i)) {
// this won't be serialized to json,
// kinda like an ES6 Symbol
Object.defineProperty(up_res.versions[i], '_verdaccio_uplink', {
Object.defineProperty(upLinkResponse.versions[i], '_verdaccio_uplink', {
value: up.upname,
enumerable: false,
configurable: false,
@ -552,7 +555,7 @@ class Storage {
}
try {
Storage._merge_versions(pkginfo, up_res, self.config);
Storage._merge_versions(packageInfo, upLinkResponse, self.config);
} catch(err) {
self.logger.error({
sub: 'out',
@ -566,18 +569,20 @@ class Storage {
exists = true;
cb();
});
}, function(err, uplink_errors) {
assert(!err && Array.isArray(uplink_errors));
}, function(err, upLinksErrors) {
assert(!err && Array.isArray(upLinksErrors));
if (!exists) {
return callback( Error[404]('no such package available')
, null
, uplink_errors );
, upLinksErrors );
}
self.localStorage.updateVersions(name, pkginfo, function(err, pkginfo) {
if (err) return callback(err);
return callback(null, pkginfo, uplink_errors);
self.localStorage.updateVersions(name, packageInfo, function(err, packageJsonLocal) {
if (err) {
return callback(err);
}
return callback(null, packageJsonLocal, upLinksErrors);
});
});
}

View file

@ -7,7 +7,7 @@ const Crypto = require('crypto');
const fs = require('fs');
const Path = require('path');
const Stream = require('stream');
const url = require('url');
const URL = require('url');
const async = require('async');
const createError = require('http-errors');
const _ = require('lodash');
@ -148,83 +148,83 @@ class LocalStorage {
/**
* Synchronize remote package info with the local one
* @param {*} name
* @param {*} newdata
* @param {*} packageInfo
* @param {*} callback
*/
updateVersions(name, newdata, callback) {
this._readCreatePackage(name, (err, data) => {
updateVersions(name, packageInfo, callback) {
this._readCreatePackage(name, (err, packageLocalJson) => {
if (err) {
return callback(err);
}
let change = false;
for (let ver in newdata.versions) {
if (_.isNil(data.versions[ver])) {
let verdata = newdata.versions[ver];
for (let versionId in packageInfo.versions) {
if (_.isNil(packageLocalJson.versions[versionId])) {
const version = packageInfo.versions[versionId];
// we don't keep readmes for package versions,
// only one readme per package
delete verdata.readme;
delete version.readme;
change = true;
data.versions[ver] = verdata;
packageLocalJson.versions[versionId] = version;
if (verdata.dist && verdata.dist.tarball) {
let filename = url.parse(verdata.dist.tarball).pathname.replace(/^.*\//, '');
if (version.dist && version.dist.tarball) {
let filename = URL.parse(version.dist.tarball).pathname.replace(/^.*\//, '');
// we do NOT overwrite any existing records
if (_.isNil(data._distfiles[filename])) {
let hash = data._distfiles[filename] = {
url: verdata.dist.tarball,
sha: verdata.dist.shasum,
if (_.isNil(packageLocalJson._distfiles[filename])) {
let hash = packageLocalJson._distfiles[filename] = {
url: version.dist.tarball,
sha: version.dist.shasum,
};
// if (verdata[Symbol('_verdaccio_uplink')]) {
if (verdata._verdaccio_uplink) {
if (version._verdaccio_uplink) {
// if we got this information from a known registry,
// use the same protocol for the tarball
//
// see https://github.com/rlidwka/sinopia/issues/166
const tarball_url = url.parse(hash.url);
const uplink_url = url.parse(this.config.uplinks[verdata._verdaccio_uplink].url);
if (uplink_url.host === tarball_url.host) {
tarball_url.protocol = uplink_url.protocol;
hash.registry = verdata._verdaccio_uplink;
hash.url = url.format(tarball_url);
const tarballUrl = URL.parse(hash.url);
const uplinkUrl = URL.parse(this.config.uplinks[version._verdaccio_uplink].url);
if (uplinkUrl.host === tarballUrl.host) {
tarballUrl.protocol = uplinkUrl.protocol;
hash.registry = version._verdaccio_uplink;
hash.url = URL.format(tarballUrl);
}
}
}
}
}
}
for (let tag in newdata['dist-tags']) {
if (!data['dist-tags'][tag] || data['dist-tags'][tag] !== newdata['dist-tags'][tag]) {
for (let tag in packageInfo['dist-tags']) {
if (!packageLocalJson['dist-tags'][tag] || packageLocalJson['dist-tags'][tag] !== packageInfo['dist-tags'][tag]) {
change = true;
data['dist-tags'][tag] = newdata['dist-tags'][tag];
packageLocalJson['dist-tags'][tag] = packageInfo['dist-tags'][tag];
}
}
for (let up in newdata._uplinks) {
if (Object.prototype.hasOwnProperty.call(newdata._uplinks, up)) {
const need_change = !Utils.is_object(data._uplinks[up])
|| newdata._uplinks[up].etag !== data._uplinks[up].etag
|| newdata._uplinks[up].fetched !== data._uplinks[up].fetched;
for (let up in packageInfo._uplinks) {
if (Object.prototype.hasOwnProperty.call(packageInfo._uplinks, up)) {
const need_change = !Utils.is_object(packageLocalJson._uplinks[up])
|| packageInfo._uplinks[up].etag !== packageLocalJson._uplinks[up].etag
|| packageInfo._uplinks[up].fetched !== packageLocalJson._uplinks[up].fetched;
if (need_change) {
change = true;
data._uplinks[up] = newdata._uplinks[up];
packageLocalJson._uplinks[up] = packageInfo._uplinks[up];
}
}
}
if (newdata.readme !== data.readme) {
data.readme = newdata.readme;
if (packageInfo.readme !== packageLocalJson.readme) {
packageLocalJson.readme = packageInfo.readme;
change = true;
}
if (change) {
this.logger.debug('updating package info');
this._writePackage(name, data, function(err) {
callback(err, data);
this._writePackage(name, packageLocalJson, function(err) {
callback(err, packageLocalJson);
});
} else {
callback(null, data);
callback(null, packageLocalJson);
}
});
}