mirror of
https://github.com/verdaccio/verdaccio.git
synced 2025-01-06 22:40:26 -05:00
Merge pull request #1278 from jinliming2/fix-logo
fix: logo field in configuration cannot use the local file
This commit is contained in:
commit
65f5ba3676
3 changed files with 57 additions and 14 deletions
|
@ -8,7 +8,7 @@ import fs from 'fs';
|
||||||
import path from 'path';
|
import path from 'path';
|
||||||
import express from 'express';
|
import express from 'express';
|
||||||
|
|
||||||
import { combineBaseUrl, getWebProtocol } from '../../lib/utils';
|
import { combineBaseUrl, getWebProtocol, isHTTPProtocol } from '../../lib/utils';
|
||||||
import Search from '../../lib/search';
|
import Search from '../../lib/search';
|
||||||
import { HEADERS, HTTP_STATUS, WEB_TITLE } from '../../lib/constants';
|
import { HEADERS, HTTP_STATUS, WEB_TITLE } from '../../lib/constants';
|
||||||
import loadPlugin from '../../lib/plugin-loader';
|
import loadPlugin from '../../lib/plugin-loader';
|
||||||
|
@ -32,6 +32,17 @@ export function loadTheme(config) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
const sendFileCallback = next => err => {
|
||||||
|
if (!err) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (err.status === HTTP_STATUS.NOT_FOUND) {
|
||||||
|
next();
|
||||||
|
} else {
|
||||||
|
next(err);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
module.exports = function(config, auth, storage) {
|
module.exports = function(config, auth, storage) {
|
||||||
Search.configureStorage(storage);
|
Search.configureStorage(storage);
|
||||||
/* eslint new-cap:off */
|
/* eslint new-cap:off */
|
||||||
|
@ -43,21 +54,24 @@ module.exports = function(config, auth, storage) {
|
||||||
const indexTemplate = path.join(themePath, 'index.html');
|
const indexTemplate = path.join(themePath, 'index.html');
|
||||||
const template = fs.readFileSync(indexTemplate).toString();
|
const template = fs.readFileSync(indexTemplate).toString();
|
||||||
|
|
||||||
|
// Logo
|
||||||
|
let logoURI = _.get(config, 'web.logo') ? config.web.logo : '';
|
||||||
|
if (logoURI && !isHTTPProtocol(logoURI)) {
|
||||||
|
// URI related to a local file
|
||||||
|
|
||||||
|
// Note: `path.join` will break on Windows, because it transforms `/` to `\`
|
||||||
|
// Use POSIX version `path.posix.join` instead.
|
||||||
|
logoURI = path.posix.join('/-/static/', path.basename(logoURI));
|
||||||
|
router.get(logoURI, function(req, res, next) {
|
||||||
|
res.sendFile(path.resolve(config.web.logo), sendFileCallback(next));
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
// Static
|
// Static
|
||||||
router.get('/-/static/*', function(req, res, next) {
|
router.get('/-/static/*', function(req, res, next) {
|
||||||
const filename = req.params[0];
|
const filename = req.params[0];
|
||||||
|
|
||||||
const file = `${themePath}/${filename}`;
|
const file = `${themePath}/${filename}`;
|
||||||
res.sendFile(file, function(err) {
|
res.sendFile(file, sendFileCallback(next));
|
||||||
if (!err) {
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
if (err.status === HTTP_STATUS.NOT_FOUND) {
|
|
||||||
next();
|
|
||||||
} else {
|
|
||||||
next(err);
|
|
||||||
}
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
|
|
||||||
function renderHTML(req, res) {
|
function renderHTML(req, res) {
|
||||||
|
@ -66,7 +80,7 @@ module.exports = function(config, auth, storage) {
|
||||||
.replace(/ToReplaceByVerdaccio/g, base)
|
.replace(/ToReplaceByVerdaccio/g, base)
|
||||||
.replace(/ToReplaceByVersion/g, pkgJSON.version)
|
.replace(/ToReplaceByVersion/g, pkgJSON.version)
|
||||||
.replace(/ToReplaceByTitle/g, _.get(config, 'web.title') ? config.web.title : WEB_TITLE)
|
.replace(/ToReplaceByTitle/g, _.get(config, 'web.title') ? config.web.title : WEB_TITLE)
|
||||||
.replace(/ToReplaceByLogo/g, _.get(config, 'web.logo') ? config.web.logo : '')
|
.replace(/ToReplaceByLogo/g, logoURI)
|
||||||
.replace(/ToReplaceByPrimaryColor/g, _.get(config, 'web.primary_color') ? config.web.primary_color : '')
|
.replace(/ToReplaceByPrimaryColor/g, _.get(config, 'web.primary_color') ? config.web.primary_color : '')
|
||||||
.replace(/ToReplaceByScope/g, _.get(config, 'web.scope') ? config.web.scope : '');
|
.replace(/ToReplaceByScope/g, _.get(config, 'web.scope') ? config.web.scope : '');
|
||||||
|
|
||||||
|
|
|
@ -547,3 +547,11 @@ export function formatAuthor(author: any) {
|
||||||
|
|
||||||
return authorDetails;
|
return authorDetails;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Check if URI is starting with "http://", "https://" or "//"
|
||||||
|
* @param {string} uri
|
||||||
|
*/
|
||||||
|
export function isHTTPProtocol(uri: string): boolean {
|
||||||
|
return /^(https?:)?\/\//.test(uri);
|
||||||
|
}
|
||||||
|
|
|
@ -14,7 +14,8 @@ import {
|
||||||
getWebProtocol,
|
getWebProtocol,
|
||||||
getVersionFromTarball,
|
getVersionFromTarball,
|
||||||
sortByName,
|
sortByName,
|
||||||
formatAuthor
|
formatAuthor,
|
||||||
|
isHTTPProtocol,
|
||||||
} from '../../../src/lib/utils';
|
} from '../../../src/lib/utils';
|
||||||
import { DIST_TAGS, DEFAULT_USER } from '../../../src/lib/constants';
|
import { DIST_TAGS, DEFAULT_USER } from '../../../src/lib/constants';
|
||||||
import Logger, { setup } from '../../../src/lib/logger';
|
import Logger, { setup } from '../../../src/lib/logger';
|
||||||
|
@ -332,6 +333,26 @@ describe('Utilities', () => {
|
||||||
|
|
||||||
expect(url).toMatch('/-/static/logo.png');
|
expect(url).toMatch('/-/static/logo.png');
|
||||||
});
|
});
|
||||||
|
|
||||||
|
test('should check HTTP protocol correctly', () => {
|
||||||
|
expect(isHTTPProtocol('http://domain.com/-/static/logo.png')).toBeTruthy();
|
||||||
|
expect(isHTTPProtocol('https://www.domain.com/-/static/logo.png')).toBeTruthy();
|
||||||
|
expect(isHTTPProtocol('//domain.com/-/static/logo.png')).toBeTruthy();
|
||||||
|
expect(isHTTPProtocol('file:///home/user/logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('file:///F:/home/user/logo.png')).toBeFalsy();
|
||||||
|
// Note that uses ftp protocol in src was deprecated in modern browsers
|
||||||
|
expect(isHTTPProtocol('ftp://1.2.3.4/home/user/logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('./logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('.\\logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('../logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('..\\logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('../../static/logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('..\\..\\static\\logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('.logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('/static/logo.png')).toBeFalsy();
|
||||||
|
expect(isHTTPProtocol('F:\\static\\logo.png')).toBeFalsy();
|
||||||
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
describe('User utilities', () => {
|
describe('User utilities', () => {
|
||||||
|
|
Loading…
Reference in a new issue