1
0
mirror of https://github.com/Unleash/unleash.git synced 2025-01-16 00:06:40 +01:00
unleash.unleash/bin/unleash.js

62 lines
1.7 KiB
JavaScript
Raw Normal View History

#!/usr/bin/env node
'use strict';
process.env.NODE_ENV = 'production';
2016-12-02 16:34:05 +01:00
const serverImpl = require('../lib/server-impl.js');
const fs = require('fs');
2016-12-03 13:45:22 +01:00
const argv = require('yargs')
.usage('$0 [options]')
.env(true)
.option('port', {
alias: 'p',
describe: 'The HTTP port you want to start unleash on',
demand: false,
default: 4242,
type: 'number',
})
.option('host', {
alias: 'l',
describe: 'The HTTP address the server will accept connections on.',
demand: false,
type: 'string',
})
2016-12-03 13:45:22 +01:00
.option('databaseUrl', {
alias: 'd',
describe:
'The full databaseUrl to connect to, including username and password. Either databaseUrl or databaseUrlFile is required.',
demand: false,
type: 'string',
})
.option('databaseUrlFile', {
alias: 'f',
describe:
'The full path to a file containing the full database url to connect to, including username and password. When this option is supplied, it takes precedence over databaseUrl.',
demand: false,
2016-12-03 13:45:22 +01:00
type: 'string',
})
.check(args => args.databaseUrl || args.databaseUrlFile)
.option('databaseSchema', {
alias: 's',
describe: 'The database schema to use',
default: 'public',
demand: false,
type: 'string',
}).argv;
2016-12-03 13:45:22 +01:00
if (argv.databaseUrlFile) {
argv.databaseUrl = fs.readFileSync(process.env.DATABASE_URL_FILE, 'utf8');
delete argv.databaseUrlFile;
}
serverImpl
.start(argv)
.then(instance => {
2018-05-06 12:50:43 +02:00
const address = instance.server.address();
console.log(
2018-05-06 12:50:43 +02:00
`Unleash started on http://${address.address}:${address.port}`
);
})
.catch(console.err);