vbuild
Version:
Fast prototype and distribute modern web apps like a pro.
65 lines (54 loc) • 1.7 kB
JavaScript
const path = require('path')
const express = require('express')
const proxyMiddleware = require('http-proxy-middleware')
module.exports = function (compiler, options = {}) {
const server = express()
const port = options.port || 4000
const host = options.host || 'localhost'
const devMiddleWare = require('webpack-dev-middleware')(compiler, {
quiet: true,
publicPath: compiler.options.output.publicPath,
path: `http://${host}:${port}/__webpack_hmr`
})
server.use(devMiddleWare)
server.use(require('webpack-hot-middleware')(compiler, {
log: () => null
}))
if (options.setupDevServer) {
options.setupDevServer(server)
}
const mfs = devMiddleWare.fileSystem
const file = path.join(compiler.options.output.path, 'index.html')
// proxy api requests
if (typeof options.proxy === 'string') {
server.use(proxyMiddleware('/api', {
target: options.proxy,
changeOrigin: true,
pathRewrite: {
'^/api': ''
}
}))
} else if (typeof options.proxy === 'object') {
Object.keys(options.proxy).forEach(context => {
let proxyOptions = options.proxy[context]
if (typeof proxyOptions === 'string') {
proxyOptions = {
target: proxyOptions,
changeOrigin: true,
pathRewrite: {
[`^${context}`]: ''
}
}
}
server.use(proxyMiddleware(context, proxyOptions))
})
}
server.use(require('connect-history-api-fallback')({ index: '/' }))
server.get('/', (req, res) => {
devMiddleWare.waitUntilValid(() => {
const html = mfs.readFileSync(file)
res.end(html)
})
})
return { server, devMiddleWare, port, host }
}