-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathserver.js
86 lines (74 loc) · 2.75 KB
/
server.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
/* eslint-disable no-console */
/**
* Setup and run the development server for Hot-Module-Replacement
* https://webpack.github.io/docs/hot-module-replacement-with-webpack.html
*/
import express from 'express';
import webpack from 'webpack';
import webpackDevMiddleware from 'webpack-dev-middleware';
import webpackHotMiddleware from 'webpack-hot-middleware';
import StringReplacePlugin from 'string-replace-webpack-plugin';
import { spawn } from 'child_process';
import * as LoggerSettings from './app/utils/LoggerSettings';
import config from './webpack.config.development';
/* On DEV we want to keep using browser console functions for logging since is the only way
to see the origin (file and line) of the log.
Note: Dont add it to webpack.config.development because that file might be used not only for DEV.*/
if (process.env.FORCE_LOGGER !== 'true') {
let keepDebugLogsFor = LoggerSettings.getDefaultConfig(process.env.NODE_ENV).keepDebugLogsFor;
if (keepDebugLogsFor) {
keepDebugLogsFor = keepDebugLogsFor.length ? keepDebugLogsFor : ['.jsx?'];
} else {
keepDebugLogsFor = [];
}
keepDebugLogsFor = new RegExp(`${keepDebugLogsFor.map(f => f.replace('.', '\\.')).join('|')}|node_modules.*$`);
config.module.loaders.push(
{
test: /\.jsx?$/,
exclude: /node_modules/,
loader: StringReplacePlugin.replace({
replacements: [{ pattern: /logger.log/g, replacement: () => ('console.log') },
{ pattern: /logger.debug/g, replacement: () => ('console.debug') },
{ pattern: /logger.warn/g, replacement: () => ('console.warn') },
{ pattern: /logger.error/g, replacement: () => ('console.error') }
],
})
},
{
test: /\.jsx?$/,
exclude: keepDebugLogsFor,
loader: StringReplacePlugin.replace({
replacements: [{ pattern: /logger.debug/g, replacement: () => ('// console.debug') }],
})
});
}
const argv = require('minimist')(process.argv.slice(2));
const app = express();
const compiler = webpack(config);
const PORT = process.env.PORT || 3000;
const wdm = webpackDevMiddleware(compiler, {
publicPath: config.output.publicPath,
stats: {
colors: true
}
});
app.use(wdm);
app.use(webpackHotMiddleware(compiler));
const server = app.listen(PORT, 'localhost', serverError => {
if (serverError) {
return console.error(serverError);
}
if (argv['start-hot']) {
spawn('npm', ['run', 'start-hot'], { shell: true, env: process.env, stdio: 'inherit' })
.on('close', code => process.exit(code))
.on('error', spawnError => console.error(spawnError));
}
console.log(`Listening at http://localhost:${PORT}`);
});
process.on('SIGTERM', () => {
console.log('Stopping dev server');
wdm.close();
server.close(() => {
process.exit(0);
});
});