mirror of
https://github.com/scottlamb/moonfire-nvr.git
synced 2025-01-12 23:43:22 -05:00
45abeb22de
* use content-hashed paths for static resources (except the top-level request), with immutable Cache-Control headers. This should improve cache behavior in both directions: avoid preventable HTTP requests and cause immediate refresh when needed. I had some staleness when browsing with my phone. * set up the favicons properly while I'm at it (closes #50). I used the convenient favicons-webpack-plugin to build everything from a .svg. I've hit an error similar to lovell/sharp#1593 at least once though so I might change my mind about that part if it continues to be problematic. * use http-serve's new directory traversal code for static file serving. This removes the odd behavior where files that weren't present at server startup couldn't be served. (I wasn't comfortable switching to the content-hashed paths before doing this.) It also means the static files can be served compressed. JSON API responses were already served compressed, so this closes #25. * for a given API URL, decide if we want it to be cached or not server-side. Stop using jQuery's kludgy cache-defeating _=<timestamp> URL parameter. I might start setting etags on some of these things and could serve 304 Not Modified responses if it's genuinely unmodified.
109 lines
3.3 KiB
JavaScript
109 lines
3.3 KiB
JavaScript
// vim: set et sw=2 ts=2:
|
|
//
|
|
// This file is part of Moonfire NVR, a security camera network video recorder.
|
|
// Copyright (C) 2018-2020 The Moonfire NVR Authors
|
|
//
|
|
// This program is free software: you can redistribute it and/or modify
|
|
// it under the terms of the GNU General Public License as published by
|
|
// the Free Software Foundation, either version 3 of the License, or
|
|
// (at your option) any later version.
|
|
//
|
|
// In addition, as a special exception, the copyright holders give
|
|
// permission to link the code of portions of this program with the
|
|
// OpenSSL library under certain conditions as described in each
|
|
// individual source file, and distribute linked combinations including
|
|
// the two.
|
|
//
|
|
// You must obey the GNU General Public License in all respects for all
|
|
// of the code used other than OpenSSL. If you modify file(s) with this
|
|
// exception, you may extend this exception to your version of the
|
|
// file(s), but you are not obligated to do so. If you do not wish to do
|
|
// so, delete this exception statement from your version. If you delete
|
|
// this exception statement from all source files in the program, then
|
|
// also delete it here.
|
|
//
|
|
// This program is distributed in the hope that it will be useful,
|
|
// but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
// GNU General Public License for more details.
|
|
//
|
|
// You should have received a copy of the GNU General Public License
|
|
// along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
const path = require('path');
|
|
const webpack = require('webpack');
|
|
const FaviconsWebpackPlugin = require('favicons-webpack-plugin')
|
|
const HtmlWebpackPlugin = require('html-webpack-plugin');
|
|
|
|
module.exports = {
|
|
entry: {
|
|
nvr: './ui-src/index.js',
|
|
},
|
|
output: {
|
|
filename: '[name].[chunkhash].js',
|
|
path: path.resolve('./ui-dist/'),
|
|
publicPath: '/',
|
|
},
|
|
module: {
|
|
rules: [
|
|
{
|
|
test: /\.js$/,
|
|
loader: 'babel-loader',
|
|
query: {
|
|
presets: [
|
|
['@babel/preset-env', {
|
|
targets: {
|
|
esmodules: true,
|
|
},
|
|
modules: false
|
|
}]
|
|
],
|
|
},
|
|
exclude: /(node_modules|bower_components)/,
|
|
include: [path.resolve('./ui-src')],
|
|
},
|
|
{
|
|
test: /\.png$/,
|
|
use: [
|
|
{
|
|
loader: 'file-loader',
|
|
options: {
|
|
name: '[name].[contenthash].[ext]',
|
|
},
|
|
},
|
|
],
|
|
},
|
|
{
|
|
// Load css and then in-line in head
|
|
test: /\.css$/,
|
|
use: ['style-loader', 'css-loader'],
|
|
},
|
|
],
|
|
},
|
|
plugins: [
|
|
new webpack.IgnorePlugin(/\.\/locale$/),
|
|
new HtmlWebpackPlugin({
|
|
template: './ui-src/index.html',
|
|
}),
|
|
new webpack.NormalModuleReplacementPlugin(
|
|
/node_modules\/moment\/moment\.js$/,
|
|
'./min/moment.min.js'
|
|
),
|
|
new webpack.NormalModuleReplacementPlugin(
|
|
/node_modules\/moment-timezone\/index\.js$/,
|
|
'./builds/moment-timezone-with-data-2012-2022.min.js'
|
|
),
|
|
new FaviconsWebpackPlugin({
|
|
logo: './ui-src/favicon.svg',
|
|
mode: 'webapp',
|
|
devMode: 'light',
|
|
prefix: 'favicons-[hash]/',
|
|
favicons: {
|
|
coast: false,
|
|
windows: false,
|
|
yandex: false,
|
|
},
|
|
}),
|
|
],
|
|
};
|