verdaccio/lib/cli.js

125 lines
3.5 KiB
JavaScript
Raw Normal View History

2013-10-09 17:47:55 +02:00
#!/usr/bin/env node
2014-02-23 18:20:50 +01:00
/*eslint no-sync:0*/
if (process.getuid && process.getuid() === 0) {
global.console.error("Sinopia doesn't need superuser privileges. Don't run it under root.")
}
2014-09-25 03:13:03 +02:00
process.title = 'sinopia'
require('es6-shim')
2014-09-25 03:13:03 +02:00
try {
// for debugging memory leaks
// totally optional
require('heapdump')
} catch(err) {}
2013-10-26 14:18:36 +02:00
var logger = require('./logger')
logger.setup() // default setup
var commander = require('commander')
2014-11-10 20:41:38 +01:00
var constants = require('constants')
var fs = require('fs')
2014-11-10 20:41:38 +01:00
var http = require('http')
var https = require('https')
var YAML = require('js-yaml')
var Path = require('path')
var server = require('./index')
var pkg_file = '../package.yaml'
var pkg = YAML.safeLoad(fs.readFileSync(__dirname+'/'+ pkg_file, 'utf8'))
2013-10-09 17:47:55 +02:00
commander
.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)')
.version(pkg.version)
.parse(process.argv)
2013-10-09 17:47:55 +02:00
if (commander.args.length == 1 && !commander.config) {
// handling "sinopia [config]" case if "-c" is missing in commandline
commander.config = commander.args.pop()
2013-10-09 17:47:55 +02:00
}
if (commander.args.length != 0) {
commander.help()
2013-10-09 17:47:55 +02:00
}
2013-10-26 14:18:36 +02:00
var config, config_path, have_question
2013-10-09 17:47:55 +02:00
try {
if (commander.config) {
config_path = Path.resolve(commander.config)
} else {
config_path = require('./config-path')()
}
config = YAML.safeLoad(fs.readFileSync(config_path, 'utf8'))
logger.logger.warn({ file: config_path }, 'config file - @{file}')
} catch (err) {
logger.logger.fatal({ file: config_path, err: err }, 'cannot open config file @{file}: @{!err.message}')
process.exit(1)
2013-10-09 17:47:55 +02:00
}
afterConfigLoad()
function get_hostport() {
// command line || config file || default
var hostport = commander.listen || String(config.listen || '') || '4873'
hostport = hostport.split(':')
if (hostport.length < 2) {
hostport = [ undefined, hostport[0] ]
}
if (hostport[0] == null) {
hostport[0] = 'localhost'
}
return hostport
2013-10-09 17:47:55 +02:00
}
function afterConfigLoad() {
if (!config.self_path) config.self_path = Path.resolve(config_path)
2014-11-10 20:41:38 +01:00
if (!config.https) config.https = { enable: false };
var hostport = get_hostport()
2014-11-10 20:41:38 +01:00
var app = server(config);
var webServer;
if (config.https.enable === true) { // https
try {
webServer = https.createServer({
secureProtocol: 'SSLv23_method', // disable insecure SSLv2 and SSLv3
secureOptions: constants.SSL_OP_NO_SSLv2 | constants.SSL_OP_NO_SSLv3,
key: fs.readFileSync(config.https.key),
cert: fs.readFileSync(config.https.cert)
}, app);
} catch (err) { // catch errors related to certificate loading
logger.logger.fatal({err: err}, 'cannot create server: @{err.message}')
process.exit(2)
}
} else { // http
webServer = http.createServer(app);
}
webServer
.listen(hostport[1], hostport[0])
.on('error', function(err) {
logger.logger.fatal({ err: err }, 'cannot create server: @{err.message}')
process.exit(2)
})
2013-12-19 04:17:52 +01:00
2014-11-10 20:41:38 +01:00
logger.logger.warn({
addr: (config.https.enable === true ? 'https' : 'http') + '://'+hostport[0]+':'+hostport[1]+'/',
version: 'Sinopia/'+pkg.version,
}, 'http address - @{addr}')
// undocumented stuff for tests
if (typeof(process.send) === 'function') {
process.send({ sinopia_started: hostport })
}
2013-10-09 17:47:55 +02:00
}
2013-12-10 11:29:46 +01:00
process.on('uncaughtException', function(err) {
logger.logger.fatal( { err: err }
, 'uncaught exception, please report this\n@{err.stack}' )
process.exit(255)
2013-12-10 11:29:46 +01:00
})