Browse Source

refactor cli

master
Lloyd Brookes 9 years ago
parent
commit
eee6923858
  1. 75
      bin/cli.js
  2. 14
      extend/live-reload.js
  3. 0
      lib/cli-data.js
  4. 7
      lib/local-web-server.js
  5. 1
      package.json

75
bin/cli.js

@ -1,41 +1,35 @@
#!/usr/bin/env node #!/usr/bin/env node
'use strict' 'use strict'
const localWebServer = require('../')
const cliOptions = require('../lib/cli-options')
const commandLineArgs = require('command-line-args')
const cli = require('../lib/cli-data')
const commandLineUsage = require('command-line-usage') const commandLineUsage = require('command-line-usage')
const ansi = require('ansi-escape-sequences') const ansi = require('ansi-escape-sequences')
const loadConfig = require('config-master')
const path = require('path') const path = require('path')
const os = require('os')
const arrayify = require('array-back') const arrayify = require('array-back')
const t = require('typical') const t = require('typical')
const flatten = require('reduce-flatten')
const usage = commandLineUsage(cliOptions.usageData)
function ws () {
const usage = commandLineUsage(cli.usageData)
let options
let isHttps = false
let options
try {
try {
options = collectOptions() options = collectOptions()
} catch (err) {
} catch (err) {
stop([ `[red]{Error}: ${err.message}`, usage ], 1) stop([ `[red]{Error}: ${err.message}`, usage ], 1)
return return
}
}
if (options.misc.help) {
if (options.misc.help) {
stop(usage, 0) stop(usage, 0)
} else if (options.misc.config) {
} else if (options.misc.config) {
stop(JSON.stringify(options.server, null, ' '), 0) stop(JSON.stringify(options.server, null, ' '), 0)
} else {
const valid = validateOptions(options)
if (!valid) {
/* gracefully end the process */
return
}
} else {
const localWebServer = require('../')
const Koa = require('koa') const Koa = require('koa')
const valid = validateOptions(options, usage)
if (!valid) return
const app = new Koa() const app = new Koa()
app.on('error', err => { app.on('error', err => {
@ -81,7 +75,6 @@ if (options.misc.help) {
if (options.server.key && options.server.cert) { if (options.server.key && options.server.cert) {
const https = require('https') const https = require('https')
const fs = require('fs') const fs = require('fs')
isHttps = true
const serverOptions = { const serverOptions = {
key: fs.readFileSync(options.server.key), key: fs.readFileSync(options.server.key),
@ -89,9 +82,10 @@ if (options.misc.help) {
} }
const server = https.createServer(serverOptions, app.callback()) const server = https.createServer(serverOptions, app.callback())
server.listen(options.server.port, onServerUp)
server.listen(options.server.port, onServerUp.bind(null, options, true))
} else { } else {
app.listen(options.server.port, onServerUp)
app.listen(options.server.port, onServerUp.bind(null, options))
}
} }
} }
@ -100,13 +94,8 @@ function stop (msgs, exitCode) {
process.exitCode = exitCode process.exitCode = exitCode
} }
function onServerUp () {
let ipList = Object.keys(os.networkInterfaces())
.map(key => os.networkInterfaces()[key])
.reduce(flatten, [])
.filter(iface => iface.family === 'IPv4')
ipList.unshift({ address: os.hostname() })
ipList = ipList
function onServerUp (options, isHttps) {
const ipList = getIPList(isHttps)
.map(iface => `[underline]{${isHttps ? 'https' : 'http'}://${iface.address}:${options.server.port}}`) .map(iface => `[underline]{${isHttps ? 'https' : 'http'}://${iface.address}:${options.server.port}}`)
.join(', ') .join(', ')
@ -117,12 +106,28 @@ function onServerUp () {
)) ))
} }
function getIPList (isHttps) {
const flatten = require('reduce-flatten')
const os = require('os')
let ipList = Object.keys(os.networkInterfaces())
.map(key => os.networkInterfaces()[key])
.reduce(flatten, [])
.filter(iface => iface.family === 'IPv4')
ipList.unshift({ address: os.hostname() })
return ipList
}
/**
* Return default, stored and command-line options combined
*/
function collectOptions () { function collectOptions () {
const commandLineArgs = require('command-line-args')
const loadConfig = require('config-master')
const stored = loadConfig('local-web-server') const stored = loadConfig('local-web-server')
let options = {}
/* parse command line args */ /* parse command line args */
options = commandLineArgs(cliOptions.definitions)
let options = commandLineArgs(cli.definitions)
const builtIn = { const builtIn = {
port: 8000, port: 8000,
@ -150,7 +155,7 @@ function parseRewriteRules (rules) {
}) })
} }
function validateOptions (options) {
function validateOptions (options, usage) {
let valid = true let valid = true
function invalid (msg) { function invalid (msg) {
return `[red underline]{Invalid:} [bold]{${msg}}` return `[red underline]{Invalid:} [bold]{${msg}}`
@ -162,3 +167,5 @@ function validateOptions (options) {
} }
return valid return valid
} }
ws()

14
extend/live-reload.js

@ -0,0 +1,14 @@
'use strict'
const Koa = require('koa')
const localWebServer = require('../')
const liveReload = require('koa-livereload')
const convert = require('koa-convert')
const app = new Koa()
const ws = localWebServer({
log: { format: 'dev' }
})
app.use(liveReload())
app.use(ws)
app.listen(8000)

0
lib/cli-options.js → lib/cli-data.js

7
lib/local-web-server.js

@ -37,7 +37,12 @@ module.exports = localWebServer
function localWebServer (options) { function localWebServer (options) {
options = Object.assign({ options = Object.assign({
static: {}, static: {},
serveIndex: {},
serveIndex: {
options: {
icons: true,
hidden: true
}
},
cacheControl: {}, cacheControl: {},
spa: null, spa: null,
log: {}, log: {},

1
package.json

@ -62,6 +62,7 @@
"devDependencies": { "devDependencies": {
"jsdoc-to-markdown": "^1.3.6", "jsdoc-to-markdown": "^1.3.6",
"koa-cache-control": "^1.0.0", "koa-cache-control": "^1.0.0",
"koa-livereload": "^0.1.23",
"req-then": "~0.2.4", "req-then": "~0.2.4",
"tape": "^4.5.1" "tape": "^4.5.1"
} }

Loading…
Cancel
Save