0
Fork 0
mirror of https://github.com/verdaccio/verdaccio.git synced 2025-01-13 22:48:31 -05:00

using eslint to check the code

This commit is contained in:
Alex Kocharin 2013-12-23 04:14:57 +04:00
parent 1c17291654
commit b0fa7ee2d1
9 changed files with 317 additions and 60 deletions

264
.eslint.js Normal file
View file

@ -0,0 +1,264 @@
module.exports = {
env: {
node: true,
},
/*
* 0 - disable
* Rules that more harmful than useful, or just buggy.
*
* 1 - warning
* Rules that we didn't encounter yet. You can safely ignore them,
* but I'd like to know any interesting use-cases they forbid.
*
* 2 - error
* Rules that have proven to be useful, please follow them.
*/
rules: {
// didn't understand what it does, but it fails a good code
'block-scoped-var': 0,
// fails where newlines are used to format pretty big "if":
// if (
// name.charAt(0) === "." ||
// name.match(/[\/@\s\+%:]/) ||
// name !== encodeURIComponent(name) ||
// name.toLowerCase() === "node_modules"
// ) {
'brace-style': 0,
// snake_case is more readable, what's up with you guys?
'camelcase': 0,
// if some functions are complex, they are for a good reason,
// ain't worth it
'complexity': [0, 10],
// never saw it, but self is preferred
'consistent-this': [1, 'self'],
// fails good code
'curly': 0,
// fails good code, where this notation is used for consistency:
// something['foo-bar'] = 123
// something['blahblah'] = 234
'dot-notation': 0,
// pointless in many cases (like indexOf() == -1), harmful in a few
// cases (when you do want to ignore types), fails good code
'eqeqeq': 0,
// if someone is changing prototype and makes properties enumerable,
// it's their own fault
'guard-for-in': 0,
// if some functions are complex, they are for a good reason,
// ain't worth it
'max-depth': [0, 4],
// should it really throw for every long URL?
'max-len': [0, 80, 4],
// that's obvious by just looking at the code, you don't need lint for that
'max-params': [0, 3],
// if some functions are complex, they are for a good reason,
// ain't worth it
'max-statements': [0, 10],
// that one makes sense
'new-cap': 2,
'new-parens': 1,
'no-alert': 1,
// I'm writing javascript, not some weird reduced version of it
'no-bitwise': 0,
'no-caller': 1,
// not working around IE bugs, sorry
'no-catch-shadow': 0,
// see above, IE is useful for downloading other browsers only
'no-comma-dangle': 0,
'no-cond-assign': 1,
// good for removing debugging code
'no-console': 2,
'no-control-regex': 1,
// good for removing debugging code
'no-debugger': 2,
'no-delete-var': 1,
'no-div-regex': 1,
'no-dupe-keys': 1,
// why would anyone need to check against that?
'no-else-return': 0,
// sometimes empty statement contains useful comment
'no-empty': 0,
'no-empty-class': 1,
'no-empty-label': 1,
// stupid rule
// "x == null" is "x === null || x === undefined"
'no-eq-null': 0,
'no-eval': 1,
'no-ex-assign': 1,
'no-extend-native': 1,
// fails good code, when parens are used for grouping:
// (req && req.headers['via']) ? req.headers['via'] + ', ' : ''
// not everyone remembers priority tables, you know
'no-extra-parens': 0,
// fails defensive semicolons:
// ;['foo', 'bar'].forEach(function(x) {})
'no-extra-semi': 0,
'no-fallthrough': 1,
'no-floating-decimal': 1,
'no-func-assign': 1,
'no-global-strict': 1,
'no-implied-eval': 1,
'no-invalid-regexp': 1,
'no-iterator': 1,
'no-label-var': 1,
'no-loop-func': 1,
// fails good code:
// var fs = require('fs'),
// , open = fs.open
'no-mixed-requires': [0, false],
'no-multi-str': 1,
'no-native-reassign': 1,
'no-negated-in-lhs': 1,
// XXX: not released yet
//'no-nested-ternary': 1,
'no-new': 1,
// new Array(12) is used to pre-allocate arrays
'no-new-array': 0,
'no-new-func': 1,
'no-new-object': 1,
'no-new-wrappers': 1,
'no-obj-calls': 1,
// fails good code:
// fs.open('/file', 0666, function(){})
'no-octal': 0,
// fails good code:
// console.log('\033[31m' + str + '\033[39m')
// also fails \0 which is not octal escape
'no-octal-escape': 0,
// I'm writing javascript, not some weird reduced version of it
'no-plusplus': 0,
'no-proto': 1,
// fails good code:
// if (a) {
// var x = 'foo'
// } else {
// var x = bar
// }
'no-redeclare': 0,
'no-return-assign': 1,
'no-script-url': 1,
'no-self-compare': 1,
// sometimes useful, often isn't
// probably worth enforcing
'no-shadow': 2,
'no-shadow-restricted-names': 1,
'no-spaced-func': 1,
// can't agree more, but it's a task for code review, not for lint
'no-sync': 0,
// I'm writing javascript, not some weird reduced version of it
'no-ternary': 0,
// the single most important rule in the entire ruleset
'no-undef': 2,
'no-undef-init': 1,
// it is failing our own underscores
'no-underscore-dangle': 0,
// fails function hoisting
'no-unreachable': 0,
// fails npm-style code, it's good once you get used to it:
// if (typeof(options) === 'function') callback = options, options = {}
'no-unused-expressions': 0,
// fails (function(_err) {}) where named argument is used to show what
// nth function argument means
'no-unused-vars': 0,
// fails function hoisting
'no-use-before-define': 0,
'no-with': 1,
// fails foobar( (function(){}).bind(this) )
// parens are added for readability
'no-wrap-func': 0,
// fails good code:
// var x
// if (something) {
// var y
'one-var': 0,
// the most stupid rule I ever saw
'quote-props': 0,
// fails situation when different quotes are used to avoid escaping
'quotes': [0, 'single'],
'radix': 1,
'regex-spaces': 1,
// http://blog.izs.me/post/2353458699/an-open-letter-to-javascript-leaders-regarding
'semi': 0,
// fails good code where spaces are used for grouping:
// (x+y * y+z)
'space-infix-ops': 0,
'space-return-throw-case': 1,
// typeof(something) should have braces to look like a function
// a matter of taste I suppose
'space-unary-word-ops': 0,
// strict mode is just harmful,
// can I have a check to enforce not using it?
'strict': 0,
'unnecessary-strict': 1,
'use-isnan': 1,
'wrap-iife': 1,
'wrap-regex': 1,
},
}

View file

@ -1,7 +1,7 @@
#!/usr/bin/env node #!/usr/bin/env node
if (process.getuid() === 0) { if (process.getuid() === 0) {
console.error("Sinopia doesn't need superuser privileges. Don't run it under root.") global.console.error("Sinopia doesn't need superuser privileges. Don't run it under root.")
} }
var logger = require('./logger') var logger = require('./logger')
@ -43,7 +43,7 @@ try {
var readline = require('readline') var readline = require('readline')
var rl = readline.createInterface(process.stdin, process.stdout) var rl = readline.createInterface(process.stdin, process.stdout)
var timeout = setTimeout(function() { var timeout = setTimeout(function() {
console.log('I got tired waiting for an answer. Exitting...') global.console.log('I got tired waiting for an answer. Exitting...')
process.exit(1) process.exit(1)
}, 20000) }, 20000)
@ -61,7 +61,7 @@ try {
afterConfigLoad() afterConfigLoad()
} else if (x[0] == 'N' || x[0] == 'n') { } else if (x[0] == 'N' || x[0] == 'n') {
rl.close() rl.close()
console.log('So, you just accidentally run me in a wrong folder. Exitting...') global.console.log('So, you just accidentally run me in a wrong folder. Exitting...')
process.exit(1) process.exit(1)
} else { } else {
askUser() askUser()
@ -115,18 +115,20 @@ function afterConfigLoad() {
function write_config_banner(def, config) { function write_config_banner(def, config) {
var hostport = get_hostport() var hostport = get_hostport()
console.log('===========================================================') var log = global.console.log
console.log(' Creating a new configuration file: "%s"', config_path)
console.log(' ') log('===========================================================')
console.log(' If you want to setup npm to work with this registry,') log(' Creating a new configuration file: "%s"', config_path)
console.log(' run following commands:') log(' ')
console.log(' ') log(' If you want to setup npm to work with this registry,')
console.log(' $ npm set registry http://%s:%s/', hostport[0], hostport[1]) log(' run following commands:')
console.log(' $ npm set always-auth true') log(' ')
console.log(' $ npm adduser') log(' $ npm set registry http://%s:%s/', hostport[0], hostport[1])
console.log(' Username: %s', def.user) log(' $ npm set always-auth true')
console.log(' Password: %s', def.pass) log(' $ npm adduser')
console.log('===========================================================') log(' Username: %s', def.user)
log(' Password: %s', def.pass)
log('===========================================================')
} }
process.on('uncaughtException', function(err) { process.on('uncaughtException', function(err) {

View file

@ -2,7 +2,7 @@ var fs = require('fs')
, Path = require('path') , Path = require('path')
, crypto = require('crypto') , crypto = require('crypto')
, assert = require('assert') , assert = require('assert')
, fs_storage = require('./local-fs') , FS_Storage = require('./local-fs')
, UError = require('./error').UserError , UError = require('./error').UserError
, utils = require('./utils') , utils = require('./utils')
, mystreams = require('./streams') , mystreams = require('./streams')
@ -17,7 +17,7 @@ function Storage(config) {
if (!(this instanceof Storage)) return new Storage(config) if (!(this instanceof Storage)) return new Storage(config)
this.config = config this.config = config
var path = Path.resolve(Path.dirname(this.config.self_path), this.config.storage) var path = Path.resolve(Path.dirname(this.config.self_path), this.config.storage)
this.storage = new fs_storage(path) this.storage = new FS_Storage(path)
this.logger = Logger.logger.child({sub: 'fs'}) this.logger = Logger.logger.child({sub: 'fs'})
return this return this
} }

View file

@ -3,20 +3,14 @@ var Logger = require('bunyan')
, utils = require('./utils') , utils = require('./utils')
function getlvl(x) { function getlvl(x) {
if (x < 15) { switch(true) {
return 'trace' case x < 15: return 'trace'
} else if (x < 25) { case x < 25: return 'debug'
return 'debug' case x < 35: return 'info'
} else if (x < 35) { case x == 35: return 'http'
return 'info' case x < 45: return 'warn'
} else if (x == 35) { case x < 55: return 'error'
return 'http' default: return 'fatal'
} else if (x < 45) {
return 'warn'
} else if (x < 55) {
return 'error'
} else {
return 'fatal'
} }
} }

View file

@ -426,14 +426,14 @@ Storage.prototype.get_package = function(name, options, callback) {
self.local.get_package(name, options, function(err, data) { self.local.get_package(name, options, function(err, data) {
if (err && (!err.status || err.status >= 500)) { if (err && (!err.status || err.status >= 500)) {
// report internal errors right away // report internal errors right away
return cb(err) return callback(err)
} }
self._sync_package_with_uplinks(name, data, options, function(err, result, uplink_errors) { self._sync_package_with_uplinks(name, data, options, function(err, result, uplink_errors) {
if (err) return callback(err) if (err) return callback(err)
var whitelist = ['_rev', 'name', 'versions', 'dist-tags'] var whitelist = ['_rev', 'name', 'versions', 'dist-tags']
for (var i in result) { for (var i in result) {
if (!~whitelist.indexOf(i)) delete result[i] if (whitelist.indexOf(i) === -1) delete result[i]
} }
result['dist-tags'].latest = Storage._semver_sort(Object.keys(result.versions)) result['dist-tags'].latest = Storage._semver_sort(Object.keys(result.versions))

View file

@ -51,16 +51,3 @@ function add_abstract_method(self, name) {
}) })
} }
function __test() {
var test = new ReadTarball()
test.abort()
setTimeout(function() {
test.abort = function() {
console.log('ok')
}
test.abort = function() {
throw 'fail'
}
}, 100)
}

View file

@ -1,10 +1,11 @@
var URL = require('url') var URL = require('url')
, request = require('request') , request = require('request')
, stream = require('stream') , Stream = require('stream')
, UError = require('./error').UserError , UError = require('./error').UserError
, mystreams = require('./streams') , mystreams = require('./streams')
, Logger = require('./logger') , Logger = require('./logger')
, utils = require('./utils') , utils = require('./utils')
, encode = encodeURIComponent
// //
// Implements Storage interface // Implements Storage interface
@ -67,7 +68,8 @@ function _setupProxy(hostname, config, mainconfig, isHTTPS) {
if (no_proxy_item[0] !== '.') no_proxy_item = '.' + no_proxy_item if (no_proxy_item[0] !== '.') no_proxy_item = '.' + no_proxy_item
if (hostname.lastIndexOf(no_proxy_item) === hostname.length - no_proxy_item.length) { if (hostname.lastIndexOf(no_proxy_item) === hostname.length - no_proxy_item.length) {
if (this.proxy) { if (this.proxy) {
this.logger.debug({url: this.url.href, rule: no_proxy_item}, 'not using proxy for @{url}, excluded by @{rule} rule') this.logger.debug({url: this.url.href, rule: no_proxy_item},
'not using proxy for @{url}, excluded by @{rule} rule')
this.proxy = false this.proxy = false
} }
break break
@ -79,13 +81,14 @@ function _setupProxy(hostname, config, mainconfig, isHTTPS) {
if (typeof(this.proxy) !== 'string') { if (typeof(this.proxy) !== 'string') {
delete this.proxy delete this.proxy
} else { } else {
this.logger.debug({url: this.url.href, proxy: this.proxy}, 'using proxy @{proxy} for @{url}') this.logger.debug({url: this.url.href, proxy: this.proxy},
'using proxy @{proxy} for @{url}')
} }
} }
Storage.prototype.request = function(options, cb) { Storage.prototype.request = function(options, cb) {
if (!this.status_check()) { if (!this.status_check()) {
var req = new stream.Readable() var req = new Stream.Readable()
process.nextTick(function() { process.nextTick(function() {
if (typeof(cb) === 'function') cb(new Error('uplink is offline')) if (typeof(cb) === 'function') cb(new Error('uplink is offline'))
req.emit('error', new Error('uplink is offline')) req.emit('error', new Error('uplink is offline'))
@ -177,11 +180,11 @@ Storage.prototype.status_check = function(alive) {
if (arguments.length === 0) { if (arguments.length === 0) {
return true // hold off this feature until v0.6.0 return true // hold off this feature until v0.6.0
if (!this.is_alive && Math.abs(Date.now() - this.is_alive_time) < 2*60*1000) { /* if (!this.is_alive && Math.abs(Date.now() - this.is_alive_time) < 2*60*1000) {
return false return false
} else { } else {
return true return true
} }*/
} else { } else {
if (this.is_alive && !alive) { if (this.is_alive && !alive) {
this.logger.warn({host: this.url.host}, 'host @{host} is now offline') this.logger.warn({host: this.url.host}, 'host @{host} is now offline')
@ -206,7 +209,7 @@ Storage.prototype.add_package = function(name, metadata, options, callback) {
if (typeof(options) === 'function') callback = options, options = {} if (typeof(options) === 'function') callback = options, options = {}
this.request({ this.request({
uri: '/' + escape(name), uri: '/' + encode(name),
method: 'PUT', method: 'PUT',
json: metadata, json: metadata,
}, function(err, res, body) { }, function(err, res, body) {
@ -222,7 +225,7 @@ Storage.prototype.add_version = function(name, version, metadata, tag, options,
if (typeof(options) === 'function') callback = options, options = {} if (typeof(options) === 'function') callback = options, options = {}
this.request({ this.request({
uri: '/' + escape(name) + '/' + escape(version) + '/-tag/' + escape(tag), uri: '/' + encode(name) + '/' + encode(version) + '/-tag/' + encode(tag),
method: 'PUT', method: 'PUT',
json: metadata, json: metadata,
}, function(err, res, body) { }, function(err, res, body) {
@ -241,7 +244,7 @@ Storage.prototype.add_tarball = function(name, filename, options) {
, self = this , self = this
var wstream = this.request({ var wstream = this.request({
uri: '/' + escape(name) + '/-/' + escape(filename) + '/whatever', uri: '/' + encode(name) + '/-/' + encode(filename) + '/whatever',
method: 'PUT', method: 'PUT',
headers: { headers: {
'Content-Type': 'application/octet-stream' 'Content-Type': 'application/octet-stream'
@ -286,7 +289,7 @@ Storage.prototype.get_package = function(name, options, callback) {
this._add_proxy_headers(options.req, headers) this._add_proxy_headers(options.req, headers)
this.request({ this.request({
uri: '/' + escape(name), uri: '/' + encode(name),
json: true, json: true,
headers: headers, headers: headers,
}, function(err, res, body) { }, function(err, res, body) {

View file

@ -79,10 +79,10 @@ module.exports.filter_tarball_urls = function(pkg, req, config) {
} }
for (var ver in pkg.versions) { for (var ver in pkg.versions) {
if (pkg.versions[ver].dist != null var dist = pkg.versions[ver].dist
&& pkg.versions[ver].dist.tarball != null) { if (dist != null && dist.tarball != null) {
pkg.versions[ver].dist.__sinopia_orig_tarball = pkg.versions[ver].dist.tarball dist.__sinopia_orig_tarball = dist.tarball
pkg.versions[ver].dist.tarball = filter(pkg.versions[ver].dist.tarball) dist.tarball = filter(dist.tarball)
} }
} }
return pkg return pkg

View file

@ -33,6 +33,10 @@ devDependencies:
rimraf: '*' rimraf: '*'
mocha: '*' mocha: '*'
# linting tools
eslint: '*'
#eslint-stylish: '*'
keywords: keywords:
- private - private
- package - package
@ -44,6 +48,7 @@ keywords:
scripts: scripts:
test: mocha ./test/functional ./test/unit test: mocha ./test/functional ./test/unit
lint: eslint -c ./.eslint.js ./lib
# we depend on streams2 stuff # we depend on streams2 stuff
# it can be replaced with isaacs/readable-stream, ask if you need to use 0.8 # it can be replaced with isaacs/readable-stream, ask if you need to use 0.8
@ -51,5 +56,7 @@ engines:
node: '>=0.10' node: '>=0.10'
preferGlobal: true preferGlobal: true
# http://www.wtfpl.net/txt/copying/
license: WTFPL license: WTFPL