bigbuffet-rw/webpack/development.ts

123 lines
2.6 KiB
TypeScript
Raw Normal View History

2020-03-27 13:59:38 -07:00
// Note: You must restart bin/webpack-dev-server for changes to take effect
console.log('Running in development mode'); // eslint-disable-line no-console
2020-03-27 13:59:38 -07:00
import { join } from 'path';
import { merge } from 'webpack-merge';
import sharedConfig from './shared';
2020-03-27 13:59:38 -07:00
import type { Configuration } from 'webpack';
import type { Configuration as DevServerConfiguration, ProxyConfigMap } from 'webpack-dev-server';
const watchOptions: Configuration['watchOptions'] = {};
2020-03-27 13:59:38 -07:00
2021-11-03 21:41:55 -07:00
const {
DEVSERVER_URL,
BACKEND_URL,
PATRON_URL,
PROXY_HTTPS_INSECURE,
} = process.env;
const DEFAULTS = {
2022-03-21 11:33:45 -07:00
DEVSERVER_URL: 'http://localhost:3036',
2021-11-03 21:41:55 -07:00
PATRON_URL: 'http://localhost:3037',
};
2020-04-21 11:34:18 -07:00
2022-11-16 05:32:32 -08:00
const { FE_SUBDIRECTORY } = require(join(__dirname, '..', 'app', 'soapbox', 'build-config'));
2020-04-21 11:34:18 -07:00
const backendEndpoints = [
'/api',
2020-04-21 18:42:19 -07:00
'/pleroma',
2020-04-21 11:34:18 -07:00
'/nodeinfo',
'/socket',
'/oauth',
'/.well-known/webfinger',
'/static',
'/main/ostatus',
'/ostatus_subscribe',
'/favicon.png',
2020-04-21 11:34:18 -07:00
];
const makeProxyConfig = (): ProxyConfigMap => {
2021-11-03 21:41:55 -07:00
const secureProxy = PROXY_HTTPS_INSECURE !== 'true';
const proxyConfig: ProxyConfigMap = {};
proxyConfig['/api/patron'] = {
2021-11-03 21:41:55 -07:00
target: PATRON_URL || DEFAULTS.PATRON_URL,
secure: secureProxy,
changeOrigin: true,
};
2020-04-21 11:34:18 -07:00
backendEndpoints.map(endpoint => {
proxyConfig[endpoint] = {
target: BACKEND_URL,
2020-04-21 11:34:18 -07:00
secure: secureProxy,
changeOrigin: true,
2020-04-21 11:34:18 -07:00
};
});
return proxyConfig;
};
2020-03-27 22:56:50 -07:00
2020-03-27 13:59:38 -07:00
if (process.env.VAGRANT) {
// If we are in Vagrant, we can't rely on inotify to update us with changed
// files, so we must poll instead. Here, we poll every second to see if
// anything has changed.
watchOptions.poll = 1000;
}
2021-11-03 21:41:55 -07:00
const devServerUrl = (() => {
try {
return new URL(DEVSERVER_URL || DEFAULTS.DEVSERVER_URL);
2021-11-03 21:41:55 -07:00
} catch {
return new URL(DEFAULTS.DEVSERVER_URL);
}
})();
const devServer: DevServerConfiguration = {
compress: true,
host: devServerUrl.hostname,
port: devServerUrl.port,
https: devServerUrl.protocol === 'https:',
hot: false,
allowedHosts: 'all',
historyApiFallback: {
disableDotRule: true,
index: join(FE_SUBDIRECTORY, '/'),
},
headers: {
'Access-Control-Allow-Origin': '*',
},
client: {
overlay: true,
},
static: {
serveIndex: true,
},
proxy: makeProxyConfig(),
};
const configuration: Configuration = {
2020-03-27 13:59:38 -07:00
mode: 'development',
cache: true,
devtool: 'source-map',
stats: {
2021-09-05 14:42:48 -07:00
preset: 'errors-warnings',
2020-03-27 13:59:38 -07:00
errorDetails: true,
},
output: {
pathinfo: true,
},
2021-09-05 14:42:48 -07:00
watchOptions: Object.assign(
{},
{ ignored: '**/node_modules/**' },
watchOptions,
),
devServer,
};
export default merge<Configuration>(sharedConfig, configuration);