Try fixing crypto node bug. Fixes #473

This commit is contained in:
Dessalines 2021-11-03 12:03:58 -04:00
parent bfb43aae77
commit cb2fdc0399

View file

@ -1,9 +1,9 @@
const webpack = require('webpack'); const webpack = require("webpack");
const MiniCssExtractPlugin = require('mini-css-extract-plugin'); const MiniCssExtractPlugin = require("mini-css-extract-plugin");
const nodeExternals = require('webpack-node-externals'); const nodeExternals = require("webpack-node-externals");
const CopyPlugin = require('copy-webpack-plugin'); const CopyPlugin = require("copy-webpack-plugin");
const RunNodeWebpackPlugin = require('run-node-webpack-plugin'); const RunNodeWebpackPlugin = require("run-node-webpack-plugin");
const { merge } = require('lodash'); const { merge } = require("lodash");
const banner = ` const banner = `
hash:[contentHash], chunkhash:[chunkhash], name:[name], filebase:[base], query:[query], file:[file] hash:[contentHash], chunkhash:[chunkhash], name:[name], filebase:[base], query:[query], file:[file]
@ -14,11 +14,12 @@ const banner = `
const base = { const base = {
output: { output: {
filename: 'js/server.js', filename: "js/server.js",
publicPath: '/', publicPath: "/",
hashFunction: "xxhash64",
}, },
resolve: { resolve: {
extensions: ['.js', '.jsx', '.ts', '.tsx'], extensions: [".js", ".jsx", ".ts", ".tsx"],
}, },
performance: { performance: {
hints: false, hints: false,
@ -27,12 +28,12 @@ const base = {
rules: [ rules: [
{ {
test: /\.(scss|css)$/i, test: /\.(scss|css)$/i,
use: [MiniCssExtractPlugin.loader, 'css-loader', 'sass-loader'], use: [MiniCssExtractPlugin.loader, "css-loader", "sass-loader"],
}, },
{ {
test: /\.(js|jsx|tsx|ts)$/, // All ts and tsx files will be process by test: /\.(js|jsx|tsx|ts)$/, // All ts and tsx files will be process by
exclude: /node_modules/, // ignore node_modules exclude: /node_modules/, // ignore node_modules
loader: 'babel-loader', loader: "babel-loader",
}, },
// Due to some weird babel issue: https://github.com/webpack/webpack/issues/11467 // Due to some weird babel issue: https://github.com/webpack/webpack/issues/11467
{ {
@ -45,10 +46,10 @@ const base = {
}, },
plugins: [ plugins: [
new MiniCssExtractPlugin({ new MiniCssExtractPlugin({
filename: 'styles/styles.css', filename: "styles/styles.css",
}), }),
new CopyPlugin({ new CopyPlugin({
patterns: [{ from: './src/assets', to: './assets' }], patterns: [{ from: "./src/assets", to: "./assets" }],
}), }),
new webpack.BannerPlugin({ new webpack.BannerPlugin({
banner, banner,
@ -59,18 +60,18 @@ const base = {
const createServerConfig = (_env, mode) => { const createServerConfig = (_env, mode) => {
const config = merge({}, base, { const config = merge({}, base, {
mode, mode,
entry: './src/server/index.tsx', entry: "./src/server/index.tsx",
output: { output: {
filename: 'js/server.js', filename: "js/server.js",
}, },
target: 'node', target: "node",
externals: [nodeExternals(), 'inferno-helmet'], externals: [nodeExternals(), "inferno-helmet"],
}); });
if (mode === 'development') { if (mode === "development") {
config.cache = { config.cache = {
type: 'filesystem', type: "filesystem",
name: 'server', name: "server",
}; };
config.plugins.push( config.plugins.push(
@ -85,16 +86,16 @@ const createServerConfig = (_env, mode) => {
const createClientConfig = (_env, mode) => { const createClientConfig = (_env, mode) => {
const config = merge({}, base, { const config = merge({}, base, {
mode, mode,
entry: './src/client/index.tsx', entry: "./src/client/index.tsx",
output: { output: {
filename: 'js/client.js', filename: "js/client.js",
}, },
}); });
if (mode === 'development') { if (mode === "development") {
config.cache = { config.cache = {
type: 'filesystem', type: "filesystem",
name: 'client', name: "client",
}; };
} }
@ -102,6 +103,6 @@ const createClientConfig = (_env, mode) => {
}; };
module.exports = (env, properties) => [ module.exports = (env, properties) => [
createServerConfig(env, properties.mode || 'development'), createServerConfig(env, properties.mode || "development"),
createClientConfig(env, properties.mode || 'development'), createClientConfig(env, properties.mode || "development"),
]; ];