diff --git a/.changeset/slow-carrots-relate.md b/.changeset/slow-carrots-relate.md
new file mode 100644
index 000000000..35f0bb6df
--- /dev/null
+++ b/.changeset/slow-carrots-relate.md
@@ -0,0 +1,6 @@
+---
+'@verdaccio/config': minor
+'@verdaccio/web': minor
+---
+
+feat(web): add a config item to web,let the developer can select whet……her enable the html cache
diff --git a/packages/config/src/conf/default.yaml b/packages/config/src/conf/default.yaml
index b23f8492f..3e3a1e9b8 100644
--- a/packages/config/src/conf/default.yaml
+++ b/packages/config/src/conf/default.yaml
@@ -19,6 +19,7 @@ web:
# sort_packages: asc
# convert your UI to the dark side
# darkMode: true
+ # html_cache: true
# HTML tags injected after manifest
+ # bodyBefore: + # - '
' + # Public path for template manifest scripts (only manifest) + # publicPath: http://somedomain.org/ # translate your registry, api i18n not available yet # i18n: diff --git a/packages/web/src/renderHTML.ts b/packages/web/src/renderHTML.ts index 808446fdf..975195f80 100644 --- a/packages/web/src/renderHTML.ts +++ b/packages/web/src/renderHTML.ts @@ -26,6 +26,9 @@ export default function renderHTML(config, manifest, manifestFiles, req, res) { const base = getPublicUrl(config?.url_prefix, req); const basename = new URL(base).pathname; const language = config?.i18n?.web ?? DEFAULT_LANGUAGE; + const needHtmlCache = [undefined, null].includes(config?.web?.html_cache) + ? true + : config.web.html_cache; const darkMode = config?.web?.darkMode ?? false; const title = config?.web?.title ?? WEB_TITLE; const login = hasLogin(config); @@ -81,8 +84,10 @@ export default function renderHTML(config, manifest, manifestFiles, req, res) { manifest ); debug('template :: %o', webPage); - cache.set('template', webPage); - debug('set template cache'); + if (needHtmlCache) { + cache.set('template', webPage); + debug('set template cache'); + } } else { debug('reuse template cache'); } diff --git a/website/docs/web.md b/website/docs/web.md index afe8cb5ec..40ffd2ab8 100644 --- a/website/docs/web.md +++ b/website/docs/web.md @@ -33,7 +33,8 @@ web: - '' - '' scriptsbodyBefore: - - '
' + - '
' + html_cache: true ``` All access restrictions defined to [protect your packages](protect-your-dependencies.md) will also apply to the Web Interface. @@ -73,7 +74,7 @@ i18n: | scriptsBodyAfter | string[] | No | any list of strings | `>=5.0.0` | inject scripts after the
tag | | metaScripts | string[] | No | any list of strings | `>=5.0.0` | inject scripts inside
| | scriptsbodyBefore | string[] | No | any list of strings | `>=5.0.0` | inject scripts before the
| - +| html_cache | boolean | No | true | `>=v5.9.0` | whether the html cache is enabled, default true | > The recommended logo size is `40x40` pixels.