mirror of
https://github.com/weaveworks/scope.git
synced 2026-03-03 10:11:03 +00:00
* adds `?hash` to JS and CSS bundle URLs against caching in production * uses `html-webpack-plugin` to generate html dynamically * html based on template in `app/html/index.html` * per-app html files no longer needed * `build/` dir is now completely deleteable, and fully gitignored * top-level `make` now requires `client/app` to pick up on html and style changes * cleaned up `server.js` code for production bundle testing * added readme entry about testing production bundles
130 lines
3.4 KiB
JavaScript
130 lines
3.4 KiB
JavaScript
var express = require('express');
|
|
var http = require('http');
|
|
var httpProxy = require('http-proxy');
|
|
var HttpProxyRules = require('http-proxy-rules');
|
|
var url = require('url');
|
|
|
|
var app = express();
|
|
|
|
var BACKEND_HOST = process.env.BACKEND_HOST || 'localhost';
|
|
var WEBPACK_SERVER_HOST = process.env.WEBPACK_SERVER_HOST || 'localhost';
|
|
|
|
/************************************************************
|
|
*
|
|
* Express routes for:
|
|
* - app.js
|
|
* - app-terminal.js
|
|
* - index.html
|
|
*
|
|
* Proxy requests to:
|
|
* - /api -> :4040/api
|
|
*
|
|
************************************************************/
|
|
|
|
// Proxy to backend
|
|
|
|
var backendProxy = httpProxy.createProxy({
|
|
ws: true,
|
|
target: 'http://' + BACKEND_HOST + ':4040'
|
|
});
|
|
backendProxy.on('error', function(err) {
|
|
console.error('Proxy error', err);
|
|
});
|
|
app.all('/api*', backendProxy.web.bind(backendProxy));
|
|
|
|
// Serve application file depending on environment
|
|
|
|
if (process.env.NODE_ENV === 'production') {
|
|
// serve all precompiled content from build/
|
|
app.use(express.static('build'));
|
|
} else {
|
|
// redirect the JS bundles
|
|
app.get(/.*js/, function(req, res) {
|
|
res.redirect('//' + WEBPACK_SERVER_HOST + ':4041' + req.originalUrl);
|
|
});
|
|
// proxy everything else
|
|
var staticProxy = httpProxy.createProxy({
|
|
target: 'http://' + WEBPACK_SERVER_HOST + ':4041'
|
|
});
|
|
app.all('*', staticProxy.web.bind(staticProxy));
|
|
}
|
|
|
|
/*************************************************************
|
|
*
|
|
* Webpack Dev Server
|
|
*
|
|
* See: http://webpack.github.io/docs/webpack-dev-server.html
|
|
*
|
|
*************************************************************/
|
|
|
|
if (process.env.NODE_ENV !== 'production') {
|
|
var webpack = require('webpack');
|
|
var WebpackDevServer = require('webpack-dev-server');
|
|
var config = require('./webpack.local.config');
|
|
|
|
new WebpackDevServer(webpack(config), {
|
|
hot: true,
|
|
noInfo: true,
|
|
historyApiFallback: true,
|
|
stats: { colors: true }
|
|
}).listen(4041, '0.0.0.0', function (err, result) {
|
|
if (err) {
|
|
console.log(err);
|
|
}
|
|
});
|
|
}
|
|
|
|
|
|
/******************
|
|
*
|
|
* Express server
|
|
*
|
|
*****************/
|
|
|
|
var port = process.env.PORT || 4042;
|
|
var server = app.listen(port, function () {
|
|
var host = server.address().address;
|
|
var port = server.address().port;
|
|
|
|
console.log('Scope UI listening at http://%s:%s', host, port);
|
|
});
|
|
|
|
server.on('upgrade', backendProxy.ws.bind(backendProxy));
|
|
|
|
|
|
/*************************************************************
|
|
*
|
|
* path proxy server
|
|
*
|
|
*************************************************************/
|
|
|
|
var proxyRules = new HttpProxyRules({
|
|
rules: {
|
|
'/scoped/': 'http://localhost:' + port
|
|
}
|
|
});
|
|
|
|
var pathProxy = httpProxy.createProxy({ws: true});
|
|
pathProxy.on('error', function(err) { console.error('path proxy error', err); });
|
|
var pathProxyPort = port + 1;
|
|
const proxyPathServer = http.createServer(function(req, res) {
|
|
var target = proxyRules.match(req);
|
|
if (!target) {
|
|
res.writeHead(500, {'Content-Type': 'text/plain'});
|
|
res.end('No rules matched! Check out /scoped/');
|
|
return;
|
|
}
|
|
return pathProxy.web(req, res, {target: target});
|
|
}).listen(pathProxyPort, function() {
|
|
var pathProxyHost = proxyPathServer.address().address;
|
|
console.log('Scope Proxy Path UI listening at http://%s:%s/scoped/',
|
|
pathProxyHost, pathProxyPort);
|
|
});
|
|
|
|
proxyPathServer.on('upgrade', function(req, socket, head) {
|
|
var target = proxyRules.match(req);
|
|
if (target) {
|
|
return pathProxy.ws(req, socket, head, {target: target});
|
|
}
|
|
});
|