mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-20 22:52:46 -05:00
a828a5f6c0
* chore: enable tests * Update ci.yml * fix: #3174 set correctly ui values to html render * Update ci.yml * fix hex validator
112 lines
2.8 KiB
TypeScript
112 lines
2.8 KiB
TypeScript
import buildDebug from 'debug';
|
|
import LRU from 'lru-cache';
|
|
import { URL } from 'url';
|
|
|
|
import { WEB_TITLE } from '@verdaccio/config';
|
|
import { HEADERS } from '@verdaccio/core';
|
|
import { TemplateUIOptions } from '@verdaccio/types';
|
|
import { getPublicUrl } from '@verdaccio/url';
|
|
|
|
import renderTemplate from './template';
|
|
import { hasLogin, validatePrimaryColor } from './utils/web-utils';
|
|
|
|
const pkgJSON = require('../package.json');
|
|
const DEFAULT_LANGUAGE = 'es-US';
|
|
const cache = new LRU({ max: 500, maxAge: 1000 * 60 * 60 });
|
|
|
|
const debug = buildDebug('verdaccio:web:render');
|
|
|
|
const defaultManifestFiles = {
|
|
js: ['runtime.js', 'vendors.js', 'main.js'],
|
|
ico: 'favicon.ico',
|
|
};
|
|
|
|
export default function renderHTML(config, manifest, manifestFiles, req, res) {
|
|
const { url_prefix } = config;
|
|
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);
|
|
const scope = config?.web?.scope ?? '';
|
|
const logoURI = config?.web?.logo ?? '';
|
|
const pkgManagers = config?.web?.pkgManagers ?? ['yarn', 'pnpm', 'npm'];
|
|
const version = pkgJSON.version;
|
|
const flags = {
|
|
...config.flags,
|
|
};
|
|
const primaryColor = validatePrimaryColor(config?.web?.primary_color) ?? '#4b5e40';
|
|
const {
|
|
scriptsBodyAfter,
|
|
metaScripts,
|
|
scriptsbodyBefore,
|
|
showInfo,
|
|
showSettings,
|
|
showThemeSwitch,
|
|
showFooter,
|
|
showSearch,
|
|
showDownloadTarball,
|
|
} = Object.assign(
|
|
{},
|
|
{
|
|
scriptsBodyAfter: [],
|
|
bodyBefore: [],
|
|
metaScripts: [],
|
|
},
|
|
config?.web
|
|
);
|
|
const options: TemplateUIOptions = {
|
|
showInfo,
|
|
showSettings,
|
|
showThemeSwitch,
|
|
showFooter,
|
|
showSearch,
|
|
showDownloadTarball,
|
|
darkMode,
|
|
url_prefix,
|
|
basename,
|
|
base,
|
|
primaryColor,
|
|
version,
|
|
logoURI,
|
|
flags,
|
|
login,
|
|
pkgManagers,
|
|
title,
|
|
scope,
|
|
language,
|
|
};
|
|
|
|
let webPage;
|
|
|
|
try {
|
|
webPage = cache.get('template');
|
|
if (!webPage) {
|
|
webPage = renderTemplate(
|
|
{
|
|
manifest: manifestFiles ?? defaultManifestFiles,
|
|
options,
|
|
scriptsBodyAfter,
|
|
metaScripts,
|
|
scriptsbodyBefore,
|
|
},
|
|
manifest
|
|
);
|
|
if (needHtmlCache) {
|
|
cache.set('template', webPage);
|
|
debug('set template cache');
|
|
}
|
|
} else {
|
|
debug('reuse template cache');
|
|
}
|
|
} catch (error: any) {
|
|
throw new Error(`theme could not be load, stack ${error.stack}`);
|
|
}
|
|
res.setHeader('Content-Type', HEADERS.TEXT_HTML);
|
|
res.send(webPage);
|
|
debug('web rendered');
|
|
}
|