expose the right webpack bundle paths to koa.
getBundlePaths
({statsFilePath}) => [::string]
- finds the paths to javascript files by inspecting a webpack stats file:
buildExposeBundlePathsKoaMiddleware
({defaultBundlePaths, ctxPropertyName}) => (ctx, next) => ::Promise
- middleware builder that exposes the js paths on
ctx
. The script paths are extracted fromctx.state.webpackStats
if it is set, whichis useful for automatically using the script paths in conjunction with webpack-dev-middleware.
build script:
webpack --profile --json > webpack-stats.json
koa server definition:
import Koa from 'koa';
import {
getScriptPaths,
buildExposeAssetPathsKoaMiddleware,
} from 'webpack-stats-exposer';
const builtBundlePaths = getScriptPaths({statsFilePath: 'webpack-stats.json'})
const app = new Koa();
if (process.env.NODE_ENV !== 'production') {
app.use(koaWebpack({
compiler, // compiler is an instance of webpack(config)
devMiddleware: {
serverSideRender: true // required because it sets `ctx.state.webpackStats`. See https://github.com/shellscape/koa-webpack#server-side-rendering
}
}))
}
app.use(buildExposeBundlePathsKoaMiddleware({
defaultBundlePaths: builtBundlePaths,
ctxPropertyName: 'bundlePaths'
}));
app.use(ctx => {
ctx.body = `
<!doctype HTML>
<html>
<head>
<title>hello world</title>
</head>
<body>
${ctx.bundlePaths
.map(bundlePath => `<script type='application/json' src='${bundlePath}' ></script>`)
.join('\n')
}
</body>
</html>
`;
})
In the example app above, ctx.bundlePaths
will be set to the paths in the stats object at ctx.state.webpackStats
when present (i.e. when NODE_ENV !== production and
koaWebpack is used
), otherwise the bundle paths will be found in webpack-stats.json`.
So, when koa-webpack is used, the bundles that it produces will be exposed on the page, otherwise, the bundles built by the build script will be used.