diff --git a/app.js b/app.js index 45e70c8b5..878c85729 100644 --- a/app.js +++ b/app.js @@ -191,7 +191,6 @@ app.engine('ejs', ejs.renderFile) // set view engine app.set('view engine', 'ejs') // set generally available variables for all views -app.locals.useCDN = config.useCDN app.locals.serverURL = config.serverURL app.locals.sourceURL = config.sourceURL app.locals.allowAnonymous = config.allowAnonymous diff --git a/docs/content/configuration.md b/docs/content/configuration.md index c6e3fc3eb..a19c749df 100644 --- a/docs/content/configuration.md +++ b/docs/content/configuration.md @@ -98,7 +98,6 @@ these are rarely used for various reasons. | config file | environment | **default** and example value | description | | --------------- | -------------------- | ----------------------------- | ------------------------------------------------------------------------------------------------------------------------------------------------------------------------------ | | `allowGravatar` | `CMD_ALLOW_GRAVATAR` | **`true`** or `false` | set to `false` to disable [Libravatar](https://www.libravatar.org/) as profile picture source on your instance. Libravatar is a federated open-source alternative to Gravatar. | -| `useCDN` | `CMD_USECDN` | **`false`** or `true` | set to use CDN resources or not (default is `false`) | ## Users and Privileges diff --git a/lib/config/default.js b/lib/config/default.js index c1f3f9733..f98adf37b 100644 --- a/lib/config/default.js +++ b/lib/config/default.js @@ -29,7 +29,6 @@ module.exports = { }, cookiePolicy: 'lax', protocolUseSSL: false, - useCDN: false, allowAnonymous: true, allowAnonymousEdits: false, allowFreeURL: false, diff --git a/lib/config/environment.js b/lib/config/environment.js index 1a43a88f9..e9b711ff0 100644 --- a/lib/config/environment.js +++ b/lib/config/environment.js @@ -27,7 +27,6 @@ module.exports = { cookiePolicy: process.env.CMD_COOKIE_POLICY, protocolUseSSL: toBooleanConfig(process.env.CMD_PROTOCOL_USESSL), allowOrigin: toArrayConfig(process.env.CMD_ALLOW_ORIGIN), - useCDN: toBooleanConfig(process.env.CMD_USECDN), allowAnonymous: toBooleanConfig(process.env.CMD_ALLOW_ANONYMOUS), allowAnonymousEdits: toBooleanConfig(process.env.CMD_ALLOW_ANONYMOUS_EDITS), allowFreeURL: toBooleanConfig(process.env.CMD_ALLOW_FREEURL), diff --git a/lib/config/hackmdEnvironment.js b/lib/config/hackmdEnvironment.js index 76e413612..c40ffc961 100644 --- a/lib/config/hackmdEnvironment.js +++ b/lib/config/hackmdEnvironment.js @@ -20,7 +20,6 @@ module.exports = { }, protocolUseSSL: toBooleanConfig(process.env.HMD_PROTOCOL_USESSL), allowOrigin: toArrayConfig(process.env.HMD_ALLOW_ORIGIN), - useCDN: toBooleanConfig(process.env.HMD_USECDN), allowAnonymous: toBooleanConfig(process.env.HMD_ALLOW_ANONYMOUS), allowAnonymousEdits: toBooleanConfig(process.env.HMD_ALLOW_ANONYMOUS_EDITS), allowFreeURL: toBooleanConfig(process.env.HMD_ALLOW_FREEURL), diff --git a/lib/config/oldDefault.js b/lib/config/oldDefault.js index 738ad9f7d..c9af50988 100644 --- a/lib/config/oldDefault.js +++ b/lib/config/oldDefault.js @@ -6,7 +6,6 @@ module.exports = { alloworigin: undefined, usessl: undefined, protocolusessl: undefined, - usecdn: undefined, allowanonymous: undefined, allowanonymousedits: undefined, allowfreeurl: undefined, diff --git a/lib/csp.js b/lib/csp.js index 74404413c..76426d526 100644 --- a/lib/csp.js +++ b/lib/csp.js @@ -15,12 +15,6 @@ const defaultDirectives = { connectSrc: ['*'] } -const cdnDirectives = { - scriptSrc: ['https://cdnjs.cloudflare.com', 'https://cdn.mathjax.org'], - styleSrc: ['https://cdnjs.cloudflare.com', 'https://fonts.googleapis.com'], - fontSrc: ['https://cdnjs.cloudflare.com', 'https://fonts.gstatic.com'] -} - const disqusDirectives = { scriptSrc: ['https://disqus.com', 'https://*.disqus.com', 'https://*.disquscdn.com'], styleSrc: ['https://*.disquscdn.com'], @@ -39,7 +33,6 @@ CspStrategy.computeDirectives = function () { const directives = {} mergeDirectives(directives, config.csp.directives) mergeDirectivesIf(config.csp.addDefaults, directives, defaultDirectives) - mergeDirectivesIf(config.useCDN, directives, cdnDirectives) mergeDirectivesIf(config.csp.addDisqus, directives, disqusDirectives) mergeDirectivesIf(config.csp.addGoogleAnalytics, directives, googleAnalyticsDirectives) mergeDirectivesIf(config.dropbox.appKey, directives, dropboxDirectives) diff --git a/public/views/hedgedoc/footer.ejs b/public/views/hedgedoc/footer.ejs index 86572091e..c3927db77 100644 --- a/public/views/hedgedoc/footer.ejs +++ b/public/views/hedgedoc/footer.ejs @@ -1,28 +1,5 @@ -<% if(useCDN) { %> - - - - - - - - - - - - - - - - - - - -<%- include('../build/index-scripts') %> -<% } else { %> <%- include('../build/index-pack-scripts') %> -<% } %> diff --git a/public/views/hedgedoc/head.ejs b/public/views/hedgedoc/head.ejs index 419d5dcc7..c2321fccf 100644 --- a/public/views/hedgedoc/head.ejs +++ b/public/views/hedgedoc/head.ejs @@ -15,15 +15,5 @@ <% } %> <%= title %> -<% if(useCDN) { %> - - - - - -<%- include('../build/index-header') %> -<%- include('../shared/polyfill') %> -<% } else { %> <%- include('../build/index-pack-header') %> -<% } %> diff --git a/public/views/index/footer.ejs b/public/views/index/footer.ejs index c9532f6d9..c6469cc0b 100644 --- a/public/views/index/footer.ejs +++ b/public/views/index/footer.ejs @@ -1,12 +1 @@ -<% if(useCDN) { %> - - - - - - - -<%- include('../build/cover-scripts') %> -<% } else { %> <%- include('../build/cover-pack-scripts') %> -<% } %> diff --git a/public/views/index/head.ejs b/public/views/index/head.ejs index a6e79e35c..a6751bbf4 100644 --- a/public/views/index/head.ejs +++ b/public/views/index/head.ejs @@ -16,14 +16,4 @@ HedgeDoc - <%= __('Collaborative markdown notes') %> -<% if(useCDN) { %> - - - - - -<%- include('../build/cover-header') %> -<%- include('../shared/polyfill') %> -<% } else { %> <%- include('../build/cover-pack-header') %> -<% } %> diff --git a/public/views/pretty.ejs b/public/views/pretty.ejs index fc222cb8c..97274ba15 100644 --- a/public/views/pretty.ejs +++ b/public/views/pretty.ejs @@ -25,17 +25,8 @@ <%= title %> <%- include('includes/favicon.ejs') %> - <% if(useCDN) { %> - - - - - <%- include('build/pretty-header') %> - <%- include('shared/polyfill') %> - <% } else { %> <%- include('build/pretty-pack-header') %> - <% } %> @@ -80,27 +71,8 @@ -<% if(useCDN) { %> - - - - - - - - - - - - - - - -<%- include('build/pretty-scripts') %> -<% } else { %> <%- include('build/pretty-pack-scripts') %> -<% } %> <%- include('shared/ga') %> diff --git a/public/views/shared/polyfill.ejs b/public/views/shared/polyfill.ejs deleted file mode 100644 index 82b2f0253..000000000 --- a/public/views/shared/polyfill.ejs +++ /dev/null @@ -1,7 +0,0 @@ - - - diff --git a/public/views/slide.ejs b/public/views/slide.ejs index e08ca0579..5837737ce 100644 --- a/public/views/slide.ejs +++ b/public/views/slide.ejs @@ -14,19 +14,9 @@ <%= title %> <%- include('includes/favicon.ejs') %> - - <% if(useCDN) { %> - - - - - <%- include('build/slide-header') %> - <%- include('shared/polyfill') %> - <% } else { %> <%- include('build/slide-pack-header') %> - <% } %> <% if(typeof theme !== 'undefined' && theme) { %> @@ -87,29 +77,10 @@ - <% if(useCDN) { %> - - - - - - - - - - - - - - - - <%- include('build/slide-scripts') %> - <% } else { %> <%- include('build/slide-pack-scripts') %> - <% } %> diff --git a/test/csp.js b/test/csp.js index 154120221..02184662c 100644 --- a/test/csp.js +++ b/test/csp.js @@ -27,7 +27,6 @@ describe('Content security policies', function () { upgradeInsecureRequests: 'auto', reportURI: undefined }, - useCDN: true, dropbox: { appKey: undefined } @@ -44,21 +43,6 @@ describe('Content security policies', function () { csp = mock.reRequire('../lib/csp') }) - // beginnging Tests - it('Disable CDN', function () { - const testconfig = defaultConfig - testconfig.useCDN = false - mock('../lib/config', testconfig) - csp = mock.reRequire('../lib/csp') - - assert(!csp.computeDirectives().scriptSrc.includes('https://cdnjs.cloudflare.com')) - assert(!csp.computeDirectives().scriptSrc.includes('https://cdn.mathjax.org')) - assert(!csp.computeDirectives().styleSrc.includes('https://cdnjs.cloudflare.com')) - assert(!csp.computeDirectives().styleSrc.includes('https://fonts.googleapis.com')) - assert(!csp.computeDirectives().fontSrc.includes('https://cdnjs.cloudflare.com')) - assert(!csp.computeDirectives().fontSrc.includes('https://fonts.gstatic.com')) - }) - it('Disable Google Analytics', function () { const testconfig = defaultConfig testconfig.csp.addGoogleAnalytics = false diff --git a/webpack.common.js b/webpack.common.js index 48b5bf147..70175c39e 100644 --- a/webpack.common.js +++ b/webpack.common.js @@ -22,13 +22,6 @@ module.exports = { 'moment': 'moment', CodeMirror: 'codemirror/lib/codemirror.js' }), - new HtmlWebpackPlugin({ - template: 'public/views/includes/header.ejs', - chunks: ['font', 'index-styles', 'index'], - filename: path.join(__dirname, 'public/views/build/index-header.ejs'), - inject: false, - chunksSortMode: 'manual' - }), new HtmlWebpackPlugin({ template: 'public/views/includes/header.ejs', chunks: ['font-pack', 'index-styles-pack', 'index-styles', 'index'], @@ -36,12 +29,6 @@ module.exports = { inject: false, chunksSortMode: 'manual' }), - new HtmlWebpackPlugin({ - template: 'public/views/includes/scripts.ejs', - chunks: ['index'], - filename: path.join(__dirname, 'public/views/build/index-scripts.ejs'), - inject: false - }), new HtmlWebpackPlugin({ template: 'public/views/includes/scripts.ejs', chunks: ['common', 'index-pack'], @@ -49,13 +36,6 @@ module.exports = { inject: false, chunksSortMode: 'manual' }), - new HtmlWebpackPlugin({ - template: 'public/views/includes/header.ejs', - chunks: ['font', 'cover'], - filename: path.join(__dirname, 'public/views/build/cover-header.ejs'), - inject: false, - chunksSortMode: 'manual' - }), new HtmlWebpackPlugin({ template: 'public/views/includes/header.ejs', chunks: ['font-pack', 'cover-styles-pack', 'cover'], @@ -63,12 +43,6 @@ module.exports = { inject: false, chunksSortMode: 'manual' }), - new HtmlWebpackPlugin({ - template: 'public/views/includes/scripts.ejs', - chunks: ['cover'], - filename: path.join(__dirname, 'public/views/build/cover-scripts.ejs'), - inject: false - }), new HtmlWebpackPlugin({ template: 'public/views/includes/scripts.ejs', chunks: ['common', 'cover-pack'], @@ -76,13 +50,6 @@ module.exports = { inject: false, chunksSortMode: 'manual' }), - new HtmlWebpackPlugin({ - template: 'public/views/includes/header.ejs', - chunks: ['font', 'pretty-styles', 'pretty'], - filename: path.join(__dirname, 'public/views/build/pretty-header.ejs'), - inject: false, - chunksSortMode: 'manual' - }), new HtmlWebpackPlugin({ template: 'public/views/includes/header.ejs', chunks: ['font-pack', 'pretty-styles-pack', 'pretty-styles', 'pretty'], @@ -90,12 +57,6 @@ module.exports = { inject: false, chunksSortMode: 'manual' }), - new HtmlWebpackPlugin({ - template: 'public/views/includes/scripts.ejs', - chunks: ['pretty'], - filename: path.join(__dirname, 'public/views/build/pretty-scripts.ejs'), - inject: false - }), new HtmlWebpackPlugin({ template: 'public/views/includes/scripts.ejs', chunks: ['common', 'pretty-pack'], @@ -103,13 +64,6 @@ module.exports = { inject: false, chunksSortMode: 'manual' }), - new HtmlWebpackPlugin({ - template: 'public/views/includes/header.ejs', - chunks: ['font', 'slide-styles', 'slide'], - filename: path.join(__dirname, 'public/views/build/slide-header.ejs'), - inject: false, - chunksSortMode: 'manual' - }), new HtmlWebpackPlugin({ template: 'public/views/includes/header.ejs', chunks: ['font-pack', 'slide-styles-pack', 'slide-styles', 'slide'], @@ -117,12 +71,6 @@ module.exports = { inject: false, chunksSortMode: 'manual' }), - new HtmlWebpackPlugin({ - template: 'public/views/includes/scripts.ejs', - chunks: ['slide'], - filename: path.join(__dirname, 'public/views/build/slide-scripts.ejs'), - inject: false - }), new HtmlWebpackPlugin({ template: 'public/views/includes/scripts.ejs', chunks: ['slide-pack'],