Change how CDN_HOST is passed down to make assets build reproducible (#14381)
* Change how CDN_HOST is passed down to make assets build reproducible * Change webpacker/webpack configuration to dynamically load publicPath based on meta header * Fix embedded layout missing the cdn-host meta headermaster
parent
53b22d247f
commit
4c45b43cb8
@ -0,0 +1,10 @@ |
||||
import ready from '../ready'; |
||||
|
||||
export let assetHost = ''; |
||||
|
||||
ready(() => { |
||||
const cdnHost = document.querySelector('meta[name=cdn-host]'); |
||||
if (cdnHost) { |
||||
assetHost = cdnHost.content || ''; |
||||
} |
||||
}); |
@ -0,0 +1,21 @@ |
||||
// Dynamically set webpack's loading path depending on a meta header, in order
|
||||
// to share the same assets regardless of instance configuration.
|
||||
// See https://webpack.js.org/guides/public-path/#on-the-fly
|
||||
|
||||
function removeOuterSlashes(string) { |
||||
return string.replace(/^\/*/, '').replace(/\/*$/, ''); |
||||
} |
||||
|
||||
function formatPublicPath(host = '', path = '') { |
||||
let formattedHost = removeOuterSlashes(host); |
||||
if (formattedHost && !/^http/i.test(formattedHost)) { |
||||
formattedHost = `//${formattedHost}`; |
||||
} |
||||
const formattedPath = removeOuterSlashes(path); |
||||
return `${formattedHost}/${formattedPath}/`; |
||||
} |
||||
|
||||
const cdnHost = document.querySelector('meta[name=cdn-host]'); |
||||
|
||||
// eslint-disable-next-line camelcase, no-undef, no-unused-vars
|
||||
__webpack_public_path__ = formatPublicPath(cdnHost ? cdnHost.content : '', process.env.PUBLIC_OUTPUT_PATH); |
Loading…
Reference in new issue