2013-10-09 19:47:55 +04:00
|
|
|
#!/usr/bin/env node
|
|
|
|
|
2014-02-23 21:20:50 +04:00
|
|
|
/*eslint no-sync:0*/
|
|
|
|
|
2014-01-24 06:36:03 +03:00
|
|
|
if (process.getuid && process.getuid() === 0) {
|
2014-11-12 14:14:37 +03:00
|
|
|
global.console.error("Sinopia doesn't need superuser privileges. Don't run it under root.")
|
2013-12-17 20:25:17 +04:00
|
|
|
}
|
|
|
|
|
2014-09-25 05:13:03 +04:00
|
|
|
process.title = 'sinopia'
|
2014-11-12 15:05:07 +03:00
|
|
|
require('es6-shim')
|
2014-09-25 05:13:03 +04:00
|
|
|
|
2013-12-29 04:52:23 +04:00
|
|
|
try {
|
2014-11-12 14:14:37 +03:00
|
|
|
// for debugging memory leaks
|
|
|
|
// totally optional
|
|
|
|
require('heapdump')
|
|
|
|
} catch(err) {}
|
2013-12-29 04:52:23 +04:00
|
|
|
|
2013-10-26 16:18:36 +04:00
|
|
|
var logger = require('./logger')
|
|
|
|
logger.setup() // default setup
|
2013-10-11 09:32:59 +04:00
|
|
|
|
2014-11-12 14:14:37 +03:00
|
|
|
var commander = require('commander')
|
|
|
|
var fs = require('fs')
|
|
|
|
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 19:47:55 +04:00
|
|
|
|
|
|
|
commander
|
2014-11-12 14:14:37 +03:00
|
|
|
.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 19:47:55 +04:00
|
|
|
|
|
|
|
if (commander.args.length == 1 && !commander.config) {
|
2014-11-12 14:14:37 +03:00
|
|
|
// handling "sinopia [config]" case if "-c" is missing in commandline
|
|
|
|
commander.config = commander.args.pop()
|
2013-10-09 19:47:55 +04:00
|
|
|
}
|
|
|
|
|
|
|
|
if (commander.args.length != 0) {
|
2014-11-12 14:14:37 +03:00
|
|
|
commander.help()
|
2013-10-09 19:47:55 +04:00
|
|
|
}
|
|
|
|
|
2013-10-26 16:18:36 +04:00
|
|
|
var config, config_path, have_question
|
2013-10-09 19:47:55 +04:00
|
|
|
try {
|
2014-11-12 14:14:37 +03:00
|
|
|
if (commander.config) {
|
2014-11-16 16:33:03 +03:00
|
|
|
config_path = Path.resolve(commander.config)
|
2014-11-12 14:14:37 +03:00
|
|
|
} else {
|
2014-11-16 16:33:03 +03:00
|
|
|
config_path = require('./config-path')()
|
2014-11-12 14:14:37 +03:00
|
|
|
}
|
2014-11-16 16:33:03 +03:00
|
|
|
config = YAML.safeLoad(fs.readFileSync(config_path, 'utf8'))
|
2014-11-16 21:44:32 +03:00
|
|
|
logger.logger.warn({ file: config_path }, 'config file - @{file}')
|
2014-11-12 14:14:37 +03:00
|
|
|
} catch (err) {
|
|
|
|
logger.logger.fatal({ file: config_path, err: err }, 'cannot open config file @{file}: @{!err.message}')
|
|
|
|
process.exit(1)
|
2013-10-09 19:47:55 +04:00
|
|
|
}
|
|
|
|
|
2014-11-16 16:33:03 +03:00
|
|
|
afterConfigLoad()
|
2013-10-09 20:22:29 +04:00
|
|
|
|
|
|
|
function get_hostport() {
|
2014-11-12 14:14:37 +03:00
|
|
|
// 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 19:47:55 +04:00
|
|
|
}
|
2013-10-09 20:22:29 +04:00
|
|
|
|
|
|
|
function afterConfigLoad() {
|
2014-11-12 14:14:37 +03:00
|
|
|
if (!config.self_path) config.self_path = Path.resolve(config_path)
|
2013-10-09 20:22:29 +04:00
|
|
|
|
2014-11-12 14:14:37 +03:00
|
|
|
var hostport = get_hostport()
|
|
|
|
server(config)
|
|
|
|
.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 07:17:52 +04:00
|
|
|
|
2014-11-16 21:44:32 +03:00
|
|
|
logger.logger.warn({ addr: 'http://'+hostport[0]+':'+hostport[1]+'/', version: 'Sinopia/'+pkg.version }, 'http address - @{addr}')
|
2013-10-09 20:22:29 +04:00
|
|
|
|
2014-11-12 14:14:37 +03:00
|
|
|
// undocumented stuff for tests
|
|
|
|
if (typeof(process.send) === 'function') {
|
|
|
|
process.send({ sinopia_started: hostport })
|
|
|
|
}
|
2013-10-09 19:47:55 +04:00
|
|
|
}
|
|
|
|
|
2013-12-10 14:29:46 +04:00
|
|
|
process.on('uncaughtException', function(err) {
|
2014-11-12 14:14:37 +03:00
|
|
|
logger.logger.fatal( { err: err }
|
|
|
|
, 'uncaught exception, please report this\n@{err.stack}' )
|
|
|
|
process.exit(255)
|
2013-12-10 14:29:46 +04:00
|
|
|
})
|
|
|
|
|