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

Replace YAML package definitions with standard package.json, fix dependencies

This commit is contained in:
steve-p-com 2016-04-21 21:13:49 +01:00
parent dfdcaa893e
commit 6301c3f169
11 changed files with 1148 additions and 433 deletions

1
.gitignore vendored
View file

@ -1,4 +1,3 @@
/package.json
npm-debug.log npm-debug.log
sinopia-*.tgz sinopia-*.tgz
.DS_Store .DS_Store

View file

@ -1,5 +1,4 @@
node_modules node_modules
package.json
npm-debug.log npm-debug.log
sinopia-*.tgz sinopia-*.tgz

View file

@ -1,6 +1,6 @@
module.exports = function(grunt) { module.exports = function(grunt) {
grunt.initConfig({ grunt.initConfig({
pkg: grunt.file.readYAML('package.yaml'), pkg: grunt.file.readJSON('package.json'),
browserify: { browserify: {
dist: { dist: {
files: { files: {

View file

@ -28,13 +28,12 @@ var Path = require('path')
var URL = require('url') var URL = require('url')
var server = require('./index') var server = require('./index')
var Utils = require('./utils') var Utils = require('./utils')
var pkg_file = '../package.yaml' var pkginfo = require('pkginfo')(module); // eslint-disable-line no-unused-vars
var pkg = YAML.safeLoad(fs.readFileSync(__dirname+'/'+ pkg_file, 'utf8'))
commander commander
.option('-l, --listen <[host:]port>', 'host:port number to listen on (default: localhost:4873)') .option('-l, --listen <[host:]port>', 'host:port number to listen on (default: localhost:4873)')
.option('-c, --config <config.yaml>', 'use this configuration file (default: ./config.yaml)') .option('-c, --config <config.yaml>', 'use this configuration file (default: ./config.yaml)')
.version(pkg.version) .version(module.exports.version)
.parse(process.argv) .parse(process.argv)
if (commander.args.length == 1 && !commander.config) { if (commander.args.length == 1 && !commander.config) {
@ -161,7 +160,7 @@ function afterConfigLoad() {
pathname: '/', pathname: '/',
}) })
), ),
version: 'Sinopia/'+pkg.version, version: 'Sinopia/'+module.exports.version,
}, 'http address - @{addr}') }, 'http address - @{addr}')
}) })

View file

@ -1,14 +1,12 @@
var assert = require('assert') var assert = require('assert')
var Crypto = require('crypto') var Crypto = require('crypto')
var fs = require('fs')
var YAML = require('js-yaml')
var Error = require('http-errors') var Error = require('http-errors')
var minimatch = require('minimatch') var minimatch = require('minimatch')
var Path = require('path') var Path = require('path')
var LocalData = require('./local-data') var LocalData = require('./local-data')
var Utils = require('./utils') var Utils = require('./utils')
var pkg_file = '../package.yaml' var Utils = require('./utils')
var pkg = YAML.safeLoad(fs.readFileSync(__dirname+'/'+pkg_file, 'utf8')) var pkginfo = require('pkginfo')(module); // eslint-disable-line no-unused-vars
// [[a, [b, c]], d] -> [a, b, c, d] // [[a, [b, c]], d] -> [a, b, c, d]
function flatten(array) { function flatten(array) {
@ -28,7 +26,7 @@ function Config(config) {
for (var i in config) { for (var i in config) {
if (self[i] == null) self[i] = config[i] if (self[i] == null) self[i] = config[i]
} }
if (!self.user_agent) self.user_agent = 'Sinopia/'+pkg.version if (!self.user_agent) self.user_agent = 'Sinopia/'+module.exports.version
// some weird shell scripts are valid yaml files parsed as string // some weird shell scripts are valid yaml files parsed as string
assert.equal(typeof(config), 'object', 'CONFIG: it doesn\'t look like a valid config file') assert.equal(typeof(config), 'object', 'CONFIG: it doesn\'t look like a valid config file')

View file

@ -1,6 +1,6 @@
var Cookies = require('cookies') var Cookies = require('cookies')
var express = require('express') var express = require('express')
var expressJson5 = require('express-json5') var bodyParser = require('body-parser')
var Error = require('http-errors') var Error = require('http-errors')
var Path = require('path') var Path = require('path')
var Middleware = require('./middleware') var Middleware = require('./middleware')
@ -30,7 +30,7 @@ module.exports = function(config, auth, storage) {
app.use(auth.basic_middleware()) app.use(auth.basic_middleware())
//app.use(auth.bearer_middleware()) //app.use(auth.bearer_middleware())
app.use(expressJson5({ strict: false, limit: config.max_body_size || '10mb' })) app.use(bodyParser.json({ strict: false, limit: config.max_body_size || '10mb' }))
app.use(Middleware.anti_loop(config)) app.use(Middleware.anti_loop(config))
// encode / in a scoped package name to be matched as a single parameter in routes // encode / in a scoped package name to be matched as a single parameter in routes

View file

@ -51,10 +51,11 @@ module.exports = function(config, auth, storage) {
async.filterSeries(packages, function(package, cb) { async.filterSeries(packages, function(package, cb) {
auth.allow_access(package.name, req.remote_user, function(err, allowed) { auth.allow_access(package.name, req.remote_user, function(err, allowed) {
setImmediate(function () { setImmediate(function () {
cb(!err && allowed) cb(err, allowed)
}) })
}) })
}, function(packages) { }, function(err, packages) {
if (err) throw err
packages.sort(function(p1, p2) { packages.sort(function(p1, p2) {
if (p1.name < p2.name) { if (p1.name < p2.name) {
return -1; return -1;

1331
npm-shrinkwrap.json generated

File diff suppressed because it is too large Load diff

86
package.json Normal file
View file

@ -0,0 +1,86 @@
{
"name": "verdaccio",
"version": "1.4.0",
"description": "Private npm repository server",
"author": {
"name": "Alex Kocharin",
"email": "alex@kocharin.ru"
},
"repository": {
"type": "git",
"url": "git://github.com/verdaccio/verdaccio"
},
"main": "index.js",
"bin": {
"sinopia": "./bin/sinopia"
},
"dependencies": {
"JSONStream": "^1.1.1",
"async": "^2.0.0-rc.3",
"body-parser": "^1.15.0",
"bunyan": "^1.8.0",
"commander": "^2.9.0",
"compression": "^1.6.1",
"cookies": "^0.6.1",
"es6-shim": "^0.35.0",
"express": "^4.13.4",
"handlebars": "^4.0.5",
"highlight.js": "^9.3.0",
"http-errors": "^1.4.0",
"jju": "^1.3.0",
"js-yaml": "^3.6.0",
"lunr": "^0.7.0",
"minimatch": "^3.0.0",
"mkdirp": "^0.5.1",
"pkginfo": "^0.4.0",
"readable-stream": "^2.1.0",
"render-readme": "^1.3.1",
"request": "^2.72.0",
"semver": "^5.1.0",
"sinopia-htpasswd": "^0.4.5",
"symbol": "^0.2.1"
},
"optionalDependencies": {
"fs-ext": "^0.5.0",
"crypt3": "^0.2.0"
},
"devDependencies": {
"rimraf": "^2.5.2",
"bluebird": "^3.3.5",
"mocha": "^2.4.5",
"eslint": "^2.8.0",
"browserify": "^13.0.0",
"browserify-handlebars": "^1.0.0",
"grunt": "^1.0.1",
"grunt-cli": "^1.2.0",
"grunt-browserify": "^5.0.0",
"grunt-contrib-less": "^1.3.0",
"grunt-contrib-watch": "^1.0.0",
"unopinionate": "^0.0.4",
"onclick": "^0.1.0",
"transition-complete": "^0.0.2"
},
"keywords": [
"private",
"package",
"repository",
"registry",
"modules",
"proxy",
"server"
],
"scripts": {
"test": "eslint . && mocha ./test/functional ./test/unit",
"test-travis": "eslint . && mocha -R spec ./test/functional ./test/unit",
"test-only": "mocha ./test/functional ./test/unit",
"lint": "eslint ."
},
"engines": {
"node": ">=0.10"
},
"preferGlobal": true,
"publishConfig": {
"registry": "https://registry.npmjs.org/"
},
"license": "WTFPL"
}

View file

@ -1,135 +0,0 @@
# use "yapm install ." if you're installing this from git repository
name: sinopia
version: 1.4.0
description: Private npm repository server
author:
name: Alex Kocharin
email: alex@kocharin.ru
repository:
type: git
url: git://github.com/rlidwka/sinopia
main: index.js
bin:
sinopia: ./bin/sinopia
dependencies:
express: '>=5.0.0-0 <6.0.0-0'
# express middlewares
express-json5: '>=0.1.0 <1.0.0-0'
body-parser: '>=1.9.2 <2.0.0-0'
compression: '>=1.2.0 <2.0.0-0'
commander: '>=2.3.0 <3.0.0-0'
js-yaml: '>=3.0.1 <4.0.0-0'
cookies: '>=0.5.0 <1.0.0-0'
request: '>=2.31.0 <3.0.0-0'
async: '>=0.9.0 <1.0.0-0'
es6-shim: '0.21.x'
semver: '>=2.2.1 <5.0.0-0'
minimatch: '>=0.2.14 <2.0.0-0'
bunyan: '>=0.22.1 <2.0.0-0'
handlebars: '2.x'
highlight.js: '8.x'
lunr: '>=0.5.2 <1.0.0-0'
render-readme: '>=0.2.1'
jju: '1.x'
JSONStream: '1.x'
mkdirp: '>=0.3.5 <1.0.0-0'
sinopia-htpasswd: '>= 0.4.3'
http-errors: '>=1.2.0'
# node 0.10 compatibility, should go away soon
readable-stream: '~1.1.0'
optionalDependencies:
# those are native modules that could fail to compile
# and unavailable on windows
fs-ext: '>=0.4.1 <1.0.0-0'
crypt3: '>=0.1.6 <1.0.0-0' # for sinopia-htpasswd
devDependencies:
#
# Tools required for testing
#
rimraf: '>=2.2.5 <3.0.0-0'
bluebird: '2 >=2.9'
mocha: '2 >=2.2.3'
#
# Linting tools
#
eslint: '1 >=1.1.0'
# for debugging memory leaks, it'll be require()'d if
# installed, but I don't want it to be installed everytime
#heapdump: '*'
#
# Tools required to build static files
#
browserify: '7.x'
browserify-handlebars: '1.x'
grunt: '>=0.4.4 <1.0.0-0'
grunt-cli: '*'
grunt-browserify: '>=2.0.8 <3.0.0-0'
grunt-contrib-less: '>=0.11.0 <1.0.0-0'
grunt-contrib-watch: '>=0.6.1 <1.0.0-0'
# for building static/main.js,
# not required in runtime
unopinionate: '>=0.0.4 <1.0.0-0'
onclick: '>=0.1.0 <1.0.0-0'
transition-complete: '>=0.0.2 <1.0.0-0'
keywords:
- private
- package
- repository
- registry
- modules
- proxy
- server
scripts:
test: eslint . && mocha ./test/functional ./test/unit
test-travis: eslint . && mocha -R spec ./test/functional ./test/unit
test-only: mocha ./test/functional ./test/unit
lint: eslint .
prepublish: js-yaml package.yaml > package.json
clean-shrinkwrap: |
node -e '
function clean(j) {
if (!j) return
for (var k in j) {
delete j[k].from
delete j[k].resolved
if (j[k].dependencies) clean(j[k].dependencies)
}
}
x = JSON.parse(require("fs").readFileSync("./npm-shrinkwrap.json"))
clean(x.dependencies)
x = JSON.stringify(x, null, " ")
require("fs").writeFileSync("./npm-shrinkwrap.json", x + "\n")
'
# we depend on streams2 stuff
# it can be replaced with isaacs/readable-stream, ask if you need to use 0.8
engines:
node: '>=0.10'
preferGlobal: true
publishConfig:
registry: https://registry.npmjs.org/
license:
type: WTFPL
url: http://www.wtfpl.net/txt/copying/

View file

@ -2,9 +2,8 @@
var assert = require('assert') var assert = require('assert')
var request = require('request') var request = require('request')
var Promise = require('bluebird') var Promise = require('bluebird')
var sym = typeof Symbol !== 'undefined' var Symbol = require('symbol')
? Symbol('smart_request_data') var sym = Symbol('smart_request_data')
: '__why_does_node_0.10_support_suck_so_much'
function smart_request(options) { function smart_request(options) {
var self = {} var self = {}