tweb-i2p/webpack.common.js

224 lines
6.7 KiB
JavaScript
Raw Normal View History

2020-02-06 22:43:07 +07:00
const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const MediaQueryPlugin = require('media-query-plugin');
const MiniCssExtractPlugin = require('mini-css-extract-plugin');
const postcssPresetEnv = require('postcss-preset-env');
const ServiceWorkerWebpackPlugin = require('serviceworker-webpack-plugin');
2021-06-14 20:05:09 +03:00
const { RetryChunkLoadPlugin } = require('webpack-retry-chunk-load-plugin');
const fs = require('fs');
const Dotenv = require('dotenv-webpack');
2020-02-06 22:43:07 +07:00
2021-04-16 22:19:36 +04:00
const allowedIPs = ['127.0.0.1'];
const devMode = process.env.NODE_ENV !== 'production';
2021-02-12 19:24:20 +04:00
const useLocal = true;
const useLocalNotLocal = true;
if(devMode) {
console.log('DEVMODE IS ON!');
}
2020-04-26 15:19:17 +03:00
const opts = {
MTPROTO_WORKER: true,
2021-03-21 21:09:20 +04:00
MTPROTO_SW: false,
MTPROTO_HTTP: false,
2021-02-13 13:59:35 +04:00
MTPROTO_HTTP_UPLOAD: false,
DEBUG: devMode,
2020-04-26 15:19:17 +03:00
version: 3,
2021-05-13 02:32:04 +04:00
'ifdef-verbose': devMode, // add this for verbose output
'ifdef-triple-slash': true, // add this to use double slash comment instead of default triple slash
'ifdef-fill-with-blanks': true // add this to remove code with blank spaces instead of "//" comments
2020-04-26 15:19:17 +03:00
};
2021-04-16 22:19:36 +04:00
const domain = 'yourdomain.com';
const localIp = '192.168.93.183';
2021-04-16 22:19:36 +04:00
2020-02-06 22:43:07 +07:00
module.exports = {
module: {
rules: [
{
test: /\.scss$/,
use: [
devMode ? 'style-loader' : MiniCssExtractPlugin.loader,/* {
loader: MiniCssExtractPlugin.loader,
options: {
hmr: devMode,
reloadAll: true,
}
}, */
'css-loader?url=false',
devMode ? undefined : MediaQueryPlugin.loader,
{
loader: 'postcss-loader',
options: {
ident: 'postcss',
plugins: [
postcssPresetEnv(),
]
}
},
{
loader: 'sass-loader',
options: {
sourceMap: devMode
}
}
].filter(l => !!l)
},
2020-02-06 22:43:07 +07:00
{
test: /\.ts?$/,
2020-04-26 15:19:17 +03:00
use: [
2020-12-29 10:08:50 +02:00
//{ loader: 'babel-loader', options: require('./babel.config') },
2020-04-26 15:19:17 +03:00
'ts-loader',
2021-05-13 02:32:04 +04:00
{ loader: 'ifdef-loader', options: opts }
2020-04-26 15:19:17 +03:00
],
2020-02-06 22:43:07 +07:00
exclude: /node_modules/,
},
{
test: /\.hbs$/,
use: [
'handlebars-loader'
]
}
2020-02-06 22:43:07 +07:00
],
},
2020-08-22 23:48:00 +03:00
2020-02-06 22:43:07 +07:00
resolve: {
2020-08-22 23:48:00 +03:00
extensions: ['.ts', '.js'],
},
2020-08-22 23:48:00 +03:00
entry: './src/index.ts',
2020-02-06 22:43:07 +07:00
/* entry: {
2021-03-21 21:09:20 +04:00
index: './src/index.ts',
pluralPolyfill: './src/lib/pluralPolyfill.ts'
2020-02-06 22:43:07 +07:00
}, */
//devtool: 'inline-source-map',
2020-08-22 23:48:00 +03:00
2020-02-06 22:43:07 +07:00
output: {
2021-05-13 02:32:04 +04:00
globalObject: 'this',
2020-02-06 22:43:07 +07:00
path: path.resolve(__dirname, 'public'),
2021-05-13 02:32:04 +04:00
filename: '[name].[chunkhash].bundle.js',
chunkFilename: '[name].[chunkhash].chunk.js'
2020-02-06 22:43:07 +07:00
},
2020-08-22 23:48:00 +03:00
2020-02-06 22:43:07 +07:00
devServer: {
contentBase: path.join(__dirname, 'public'),
watchContentBase: true,
compress: true,
2021-01-21 16:50:59 +04:00
http2: useLocalNotLocal ? true : (useLocal ? undefined : true),
https: useLocal ? undefined : {
key: fs.readFileSync(__dirname + '/certs/server-key.pem', 'utf8'),
cert: fs.readFileSync(__dirname + '/certs/server-cert.pem', 'utf8')
},
allowedHosts: useLocal ? undefined : [
2021-04-16 22:19:36 +04:00
domain
],
2021-04-16 22:19:36 +04:00
host: useLocalNotLocal ? localIp : (useLocal ? undefined : '0.0.0.0'),
public: useLocal ? undefined : domain,
//host: domain, // '0.0.0.0'
2020-12-29 10:08:50 +02:00
port: useLocal ? undefined : 443,
overlay: true,
2020-12-29 10:08:50 +02:00
before: useLocal ? undefined : function(app, server, compiler) {
app.use((req, res, next) => {
let IP = '';
if(req.headers['cf-connecting-ip']) {
IP = req.headers['cf-connecting-ip'];
} else {
IP = req.connection.remoteAddress.split(':').pop();
}
2021-01-21 16:50:59 +04:00
if(!allowedIPs.includes(IP) && !/^192\.168\.\d{1,3}\.\d{1,3}$/.test(IP)) {
console.log('Bad IP connecting: ' + IP, req.url);
res.status(404).send('Nothing interesting here.');
} else {
if(req.url.indexOf('/assets/') !== 0) {
console.log(req.url, IP);
}
next();
}
});
},
2021-04-16 22:19:36 +04:00
sockHost: useLocal ? undefined : domain,
2020-02-06 22:43:07 +07:00
},
2020-08-22 23:48:00 +03:00
2020-02-06 22:43:07 +07:00
plugins: [
new Dotenv(),
new ServiceWorkerWebpackPlugin({
2021-06-18 05:36:10 +03:00
entry: path.join(__dirname, 'src/lib/serviceWorker/index.service.ts'),
filename: 'sw.js',
2021-06-14 20:05:09 +03:00
//excludes: ['**/*'],
includes: [
'**/*.js',
'**/*.css',
'**/*.json',
'**/*.wasm',
'**/*.mp3',
'**/*.svg',
'**/*.tgs',
'**/*.ico',
'**/*.woff',
'**/*.woff2',
'**/*.ttf',
'**/*.webmanifest'
],
}),
2020-08-22 23:48:00 +03:00
2020-02-06 22:43:07 +07:00
new HtmlWebpackPlugin({
filename: `index.html`,
//template: 'public/index_template.html',
template: 'src/index.hbs',
2020-08-22 23:48:00 +03:00
inject: false, // true, 'head'
2020-06-21 15:25:17 +03:00
minify: {
2020-02-06 22:43:07 +07:00
removeComments: true,
collapseWhitespace: true,
removeRedundantAttributes: true,
useShortDoctype: true,
removeEmptyAttributes: true,
removeStyleLinkTypeAttributes: true,
keepClosingSlash: true,
minifyJS: true,
minifyCSS: true,
minifyURLs: true
2020-06-21 15:25:17 +03:00
},
2021-05-13 02:32:04 +04:00
chunks: 'all',
2020-08-22 23:48:00 +03:00
excludeChunks: []
}),
new MiniCssExtractPlugin({
// Options similar to the same options in webpackOptions.output
// both options are optional
filename: '[name].[contenthash].css',
chunkFilename: '[id].[contenthash].css',
}),
new MediaQueryPlugin({
include: [
'style'
],
queries: {
'only screen and (max-width: 720px)': 'mobile',
'only screen and (min-width: 721px)': 'desktop',
}
}),
2021-06-14 20:05:09 +03:00
new RetryChunkLoadPlugin({
// optional stringified function to get the cache busting query string appended to the script src
// if not set will default to appending the string `?cache-bust=true`
cacheBust: `function() {
return Date.now();
}`,
// optional value to set the amount of time in milliseconds before trying to load the chunk again. Default is 0
retryDelay: 3000,
// optional value to set the maximum number of retries to load the chunk. Default is 1
maxRetries: 999999,
// optional list of chunks to which retry script should be injected
// if not set will add retry script to all chunks that have webpack script loading
//chunks: ['chunkName'],
// optional code to be executed in the browser context if after all retries chunk is not loaded.
// if not set - nothing will happen and error will be returned to the chunk loader.
//lastResortScript: "window.location.href='/500.html';",
}),
2020-02-06 22:43:07 +07:00
],
};