mirror of
https://github.com/verdaccio/verdaccio.git
synced 2024-12-30 22:34:10 -05:00
shasum check for uploaded tarballs
This commit is contained in:
parent
61658cfbdc
commit
78f856cf81
2 changed files with 36 additions and 6 deletions
|
@ -154,6 +154,23 @@ Storage.prototype.add_version = function(name, version, metadata, tag, callback)
|
|||
}))
|
||||
}
|
||||
|
||||
// if uploaded tarball has a different shasum, it's very likely that we have some kind of error
|
||||
if (utils.is_object(metadata.dist) && typeof(metadata.dist.tarball) === 'string') {
|
||||
var tarball = metadata.dist.tarball.replace(/.*\//, '')
|
||||
if (utils.is_object(data._attachments[tarball])) {
|
||||
if (data._attachments[tarball].shasum != null && metadata.dist.shasum != null) {
|
||||
if (data._attachments[tarball].shasum != metadata.dist.shasum) {
|
||||
return cb(new UError({
|
||||
status: 400,
|
||||
msg: 'shasum error, ' + data._attachments[tarball].shasum + ' != ' + metadata.dist.shasum,
|
||||
}))
|
||||
}
|
||||
}
|
||||
|
||||
data._attachments[tarball].version = version
|
||||
}
|
||||
}
|
||||
|
||||
data.versions[version] = metadata
|
||||
data['dist-tags'][tag] = version
|
||||
cb()
|
||||
|
|
|
@ -1,8 +1,9 @@
|
|||
var assert = require('assert');
|
||||
var readfile = require('fs').readFileSync;
|
||||
var ex = module.exports;
|
||||
var server = process.server;
|
||||
var server2 = process.server2;
|
||||
var assert = require('assert')
|
||||
, readfile = require('fs').readFileSync
|
||||
, crypto = require('crypto')
|
||||
, ex = module.exports
|
||||
, server = process.server
|
||||
, server2 = process.server2
|
||||
|
||||
ex['trying to fetch non-existent package'] = function(cb) {
|
||||
server.get_package('testpkg', function(res, body) {
|
||||
|
@ -67,8 +68,20 @@ ex['uploading new package version for bad pkg'] = function(cb) {
|
|||
});
|
||||
};
|
||||
|
||||
ex['uploading new package version (bad sha)'] = function(cb) {
|
||||
var pkg = require('./lib/package')('testpkg')
|
||||
pkg.dist.shasum = crypto.createHash('sha1').update('fake').digest('hex')
|
||||
server.put_version('testpkg', '0.0.1', pkg, function(res, body) {
|
||||
assert.equal(res.statusCode, 400);
|
||||
assert(~body.error.indexOf('shasum error'));
|
||||
cb();
|
||||
});
|
||||
};
|
||||
|
||||
ex['uploading new package version'] = function(cb) {
|
||||
server.put_version('testpkg', '0.0.1', require('./lib/package')('testpkg'), function(res, body) {
|
||||
var pkg = require('./lib/package')('testpkg')
|
||||
pkg.dist.shasum = crypto.createHash('sha1').update(readfile('fixtures/binary')).digest('hex')
|
||||
server.put_version('testpkg', '0.0.1', pkg, function(res, body) {
|
||||
assert.equal(res.statusCode, 201);
|
||||
assert(~body.ok.indexOf('published'));
|
||||
cb();
|
||||
|
|
Loading…
Reference in a new issue